/*
	Theme Name: Demeter Elaia
	Author: id-script GmbH
	Author URI: https://www.id-script.com/
	Date: 27.05.2026
*/

:root {
	
	/* -- Typography
    ------------------------------- */
	
    --ff-body: 	"Alegreya Sans", sans-serif;
    --ff-brand: "id-script", sans-serif;
	
	/* Background: Dark */
	--bg-dark-100:			#121212;
	--bg-dark-200: 			green	;
	--bg-dark-300:			orange;

	/* Background: Light */
	--bg-light-100:         #F7F7F7;
	--bg-light-200:			#ededed;
	--bg-light-300:   		#ffffff;

	/* Headline */
	--headline-light:       #ffffff;
	--headline-dark:        #121212;
	
	/* Text */
	--text-light-100:		#ffffff;
	--text-light-200:		#767676;
	--text-dark-200:		#121212;

	/* Links */
	--link-light:           #ffffff;
	--link-dark:            #121212;
	--link-hover:       	#B85C5C;

	/* UI */
	--border-light:         #ffffff;
	--border-dark:          #121212;

	/* Diverse */
	--color-red:        	#B85C5C;
	--color-yellow:     	#FCBF02;
	--color-brand:      	#00CBFF;
	--color-blue:      		#6f9898;
	
	--section-padding:		4rem;

}


.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	overflow: hidden;
	clip: rect(0,0,0,0);
	white-space: nowrap;
	border: 0;
}

html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
}

body {
	position: relative;
	background-color: var(--bg-light-100);
	font-family: var(--ff-body);
	font-size: 1.125rem;
	font-weight: 400;
	letter-spacing: 0.015em;
	color: var(--text-dark-200);
	line-height: 1.5;
  	text-rendering: optimizeLegibility;
	touch-action: pan-y;
	overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
    color: var(--headline-dark);
	font-weight: 400;
}

h1 {
	font-size: 2.25rem;
	font-weight: 500;
}

h2 {
	font-size: 1.688rem;
}

ul {
    margin: 0;
    padding: 0;
}

p {
	margin-block-end: 1rem;
}

a {
    color: inherit;
    text-decoration: none;
	cursor: pointer;
}

.spacer {
	block-size: 80px;
	inline-size: 100%;
}

.site-width {
	max-inline-size: 1170px;
	margin-inline: auto;
}

.container {
	padding-inline: 1rem;
}

@media (min-width: 1024px) {
	.container {
		padding-inline: 3rem;
	}
}

/* Header */

.site-header {
	position: fixed;
	inset-block-start: 0;
	inset-inline-start: 0;
	inline-size: 100%;
	block-size: 80px;
	background-color: var(--bg-light-100);
	z-index: 1000;
}

.site-header .container {
	inline-size: 100%;
	block-size: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.header__logo {
    display: flex;
    justify-content: center;
    align-items: center;
    block-size: 70px;
}

.header__logo img {
    display: block;
    height: 70px;
    width: auto;
}

.header__actions {
    display: flex;
    align-items: center;
	gap: 1.5rem;
}

/* Footer */

.site-footer {
	background: var(--bg-light-200);
	font-size: 1rem;
	padding-block: var(--section-padding);
	padding-block-end: 2rem;
	
	background-image: url(img/footer-background.webp);
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}

.footer__logo {
	display: block;
	max-width: 140px;
	margin-inline: auto;
	margin-block-end: 5rem;
}

.site-footer__heading {
	font-size: 2rem;
	line-height: 1;
	margin-block-end: 1rem;
}

.site-footer__contact {
	margin-block-end: 5rem;
}

.site-footer__navigation {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
	padding-block-end: 2rem;
	margin-block-start: 3rem;
}

.site-footer--category__title {
	font-size: 1.25rem;
	font-weight: 500;
	margin-block-end: .75rem;
}

.site-footer__actions {
	margin-block-start: 2rem;
}

.site-footer__social,
.site-footer__creditcards {
    display: flex;
	gap: 0.5rem;
}

.site-footer__social {
	font-size: 1.25rem;
	margin-block-end: 1rem;
}

.site-footer__creditcards {
	margin-block-end: 1.5rem;
}

.site-footer__creditcards img {
	width: 100%;
	height: 32px;
	object-fit: contain;
}


@media (min-width: 768px) {
	.site-footer__content {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 4rem;
	}
}


/* Kontakt */

.field-wrapp {
	margin-block-end: 0.35rem;
}

fieldset {
	padding: 0;
	margin-block-start: 35px;
	border: 0;
}

label {
  font-weight: 400;
}

input[type="text"], input[type="password"], input[type="date"], input[type="datetime"], input[type="email"], input[type="number"], input[type="search"], input[type="tel"], input[type="time"], input[type="url"], input:not([type]), textarea, select, .woocommerce textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: 1px solid #ccc;
	border-radius: 4px;
	font-size: 1rem;
	font-weight: 400;
	inline-size: 100%;
	padding: .5rem;
	letter-spacing: .5px;
	background: transparent;
}

textarea {
	resize:vertical;
	block-size: 80px;
	min-block-size: 80px;
}

.lt-ie10 select {background-image: none;}

input[type="text"]:hover, input[type="text"]:focus, input[type="password"]:hover, input[type="password"]:focus, input[type="date"]:hover, input[type="date"]:focus, input[type="datetime"]:hover, input[type="datetime"]:focus, input[type="email"]:hover, input[type="email"]:focus, input[type="number"]:hover, input[type="number"]:focus, input[type="search"]:hover, input[type="search"]:focus, input[type="tel"]:hover, input[type="tel"]:focus, input[type="time"]:hover, input[type="time"]:focus, input[type="url"]:hover, input[type="url"]:focus, input:not([type]):hover, input:not([type]):focus, textarea:hover, textarea:focus,select:hover, select:focus {
    outline: 0;
}

.captcha-wrapp img {
	display: block;
	width: auto;
	margin-block-end: .5rem;
}

div.wpcf7 .ajax-loader {
    display: none;
}

.submit-wrapp {
	margin-block-start: 1.25rem;
}













/* -- Footer: Meta
------------------------------- */

.footer-meta {
	padding-block-start: 1rem;
	font-weight: 400;
}

.footer-meta .container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
}

.footer-meta__copyright {
	font-size: 0.938rem;
	margin-block: 0;
}

.footer-meta__brand {
	font-size: 0.938rem;
	transition: all 0.2s ease;
}

.footer-meta__icon {
	color: var(--color-brand);
}

.footer-meta__brand:hover {
	color: var(--color-red);
}


@media (min-width: 768px) {
	.site-content {
		padding-top: 0;
	}

	.footer__content {
		grid-template-columns: repeat(4, 1fr);
	}
	
	.item--full {
		grid-column: 3 / -1;
	}

}

@media (min-width: 1024px) {
	.site-content {
		padding-top: 80px;
	}
}





/* -- Startseite
------------------------------- */
@media (min-width: 1024px) {
	.home-hero__image {
		display: none;
	}
	
	.home-hero {
		block-size: 600px;
		inline-size: 100%;
		background-image: url(img/donkey-milk-desktop.webp);
		background-position: center center;
		background-repeat: no-repeat;
		background-size: cover;
	}	
}

/* Benefits */
.home-benefits {
	background: var(--bg-light-300);
}

.home-benefits__inner {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 20px;
}

.home-benefits__item {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 0.5rem;
}

.home-benefits__text {
	line-height: 1.15;
}

.home-benefits__icon {
	inline-size: 50px;
	margin-inline-end: 0.75rem;
}

/* Ab 768px: 4 Elemente pro Reihe */
@media (min-width: 768px) {
    .home-benefits__inner {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 768px) {
	.home-benefits__inner {
		grid-template-columns: repeat(3, 1fr);
	}

	.home-benefits__item {
		justify-content: center;
	}

}


/* Latest Products */
.home-products {
	padding-block: 2.5rem;
}

.home-products__title {
	text-align: center;
	font-size: 2rem;
	line-height: 1;
}

.home-products .woocommerce ul.products.products {
	grid-template-columns: repeat(2, 1fr);
	border: 0 none;
	margin-block-start: 0;
}

@media (min-width: 768px) {
	.home-products {
		padding-block: 4.5rem;
	}
	
	.home-products__title {
		margin-block-end: 1.25rem;
	}

    .home-products .woocommerce ul.products.products {
        grid-template-columns: repeat(4, 1fr);
    }
}



/* Produktkategorien */
.home-categories {
	border-top: 2px solid var(--bg-dark-100);
	padding-block: 2.5rem;
}

.home-categories__title {
	text-align: center;
	font-size: 2rem;
	line-height: 1;
}

.home-categories__inner {
	display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
	padding-block-start: 1.125rem;
}

@media (min-width: 768px) {
	.home-categories {
		padding-block: 4.5rem;
	}
	
	.home-categories__title {
		margin-block-end: 1.25rem;
	}

    .home-categories__inner {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Aktuell */
.home-current {
	block-size: 450px;
	inline-size: 100%;
	background-image: url(img/donkey-milk-banner1.webp);
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}

.home-current .container {
	display: flex;
	flex-wrap: wrap;
	justify-content: end;
	align-content: center;
	block-size: 100%;
}

.home-current__content {
	inline-size: 60%;
	padding: 1rem;
	text-align: right;
}

.home-current__title {
	font-size: 1.3rem;
	font-weight: 500;
	margin-block-end: 1rem;
}

@media (min-width: 768px) {
	.home-current__content {
		width: 40%;
		text-align: right;
	}
}

/* About */
.home-about {
	padding-block: 1rem;
}

.home-about__inner {
	background: #fff;
	padding: 3rem 1rem;
}

.home-about__title {
	font-size: 1.3rem;
	font-weight: 500;
	margin-block-end: 1rem;
}

@media (min-width: 768px) {
	.home-about {
		padding: 4.5rem 1rem;
	}
	
	.home-about__content {
		display: flex;
		flex-wrap: wrap;
		flex-direction: row;
		gap: 20px;
	}
	
	.home-about__body,
	.home-about__img {
		flex: 1;
	}
	
	.home-about__body {
		padding: 1.5rem 1rem;
	}
	
	.home-about__description {
		margin-block-end: 2.5rem;
	}
	
	.home-about__img {
		background-image: url(img/about-home.jpg);
		background-position: center left;
		background-repeat: no-repeat;
		background-size: cover;
	}
}


/* -- Woocommerce
------------------------------- */

aside#secondary {
	display: none;
}

.page-title {
	font-size: 2.5rem;
	margin-block-end: 1.5rem;
}

/* Breadcrumb */
.woocommerce-breadcrumb,
.woocommerce-breadcrumb a {
	font-size: 1rem;
	color: var(--text-light-200);
}

.woocommerce-products-header {
    width: 100%;
	margin-block-start: 80px;
    margin-block-end: 30px;
}

/* Title */
.woocommerce-products-header__title {
	font-size: 2.5rem;
}

/* Result Count */
.woocommerce-result-count {
	font-size: 1rem;
	color: var(--text-light-200);
}

/* Ordering */
.woocommerce-ordering {
    position: relative;
    display: inline-block;
	inline-size: 100%;
}

.woocommerce-ordering select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    inline-size: 100%;
    padding: 10px 40px 10px 15px;
    font-size: 1rem;
    border: 1px solid #ccc;
    background-color: var(--bg-light-100);
    cursor: pointer;
    border-radius: 4px;
}

.woocommerce-ordering::after {
	font-family: 'id-script';
    content: "\e800";
    font-size: 12px;
    color: var(--text-dark-200);
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%); 
    pointer-events: none;
}

.woocommerce-ordering select:hover {
    border-color: #888;
}


/* Product List */

.woocommerce ul.products {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 40px 20px;
  margin-top: 1.125rem;
  padding-top: 1.125rem;
  border-top: 1px solid var(--border-dark);
}

.woocommerce ul.products li.product {
  display: flex;
  flex-direction: column;
  height: 100%;
}



.woocommerce ul.products li.product img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
	background: var(--bg-light-200);
	margin-block-end: .25rem;
}

.woocommerce ul.products li.product a.woocommerce-loop-product__link {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
	height: 100%;
		font-size: 1rem;
	line-height: 1.05;
	color: var(--text-light-200);
	margin: 0;
}


.woocommerce ul.products li.product .woocommerce-loop-product__title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
	
		font-weight: 500;
	font-size: 1.1rem;
	padding: 0;
	margin-block-end: 0.25rem;
}

.product-short-description {
  margin-bottom: 1rem;
}


.woocommerce ul.products li.product .price {
  font-weight: 500;
  font-size: 1.3rem;
  margin-top: auto; 
  margin-bottom: 1rem;
  color: var(--headline-dark);
}

.woocommerce ul.products li.product .button {
  margin-top: auto;
}



.btn-standard,
.woocommerce .btn-standard,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce #payment #place_order {
	padding: 0.5rem 1rem;
	background: var(--bg-dark-100);
	color: var(--text-light-100);
	border: 1px solid var(--bg-dark-100);
	font-size: 1rem;
	transition: all 0.3s ease;
}

.btn-standard:hover,
.woocommerce .btn-standard:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce #payment #place_order:hover {
	background: var(--bg-light-200);
	color: var(--text-dark-100);
}

@media (min-width: 768px) {

	.archive ul.products {
		grid-template-columns: repeat(3, 1fr);
	}

	.related ul.products {
		grid-template-columns: repeat(4, 1fr);
	}
}


/* WooCommerce pagination */

nav.woocommerce-pagination {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	overflow: visible !important
}

nav.woocommerce-pagination ul {
	list-style: none;
	text-align: center;
	text-decoration: none;
	margin: 2rem auto;
}

nav.woocommerce-pagination li span.current,
nav.woocommerce-pagination li a {
	width: 50px;
	height: 50px;
	line-height: 50px;
	display: inline-block;
}

nav.woocommerce-pagination li {
	color: var(--text-light-200);
	float: left;
}

nav.woocommerce-pagination li a {
	color: var(--text-light-200);
	text-decoration: none;
}

nav.woocommerce-pagination li span.current,
nav.woocommerce-pagination li:hover {
	color: var(--color-red);
}

nav.woocommerce-pagination li span.current {
	color: var(--color-red);
}

nav.woocommerce-pagination li a.next {
	width: auto !important;
	padding: 0 2rem 0 0.8rem !important;
	position: relative;
}

nav.woocommerce-pagination li a.prev {
	width: auto !important;
	padding: 0 0.8rem 0 2rem !important;
	position: relative;
}


@media (min-width: 768px) {
	
	.woocommerce-products-header {
		margin-block-start: 120px;
	}
	
	.products::after {
		content: "";
		display: block;
		clear: both;
	}

	.woocommerce-result-count {
		display: inline-block;		
	}

	.woocommerce-ordering {
		inline-size: auto;
		float: right;
	}

	.woocommerce ul.products.products {
		clear: both;
	}

}

@media (min-width: 1024px) {

	.site-layout-grid {
		display: grid;
		grid-template-columns: 250px 1fr;
		gap: 40px;
	}
	
	aside#secondary {
		display: block;
	}
	
	.aside-container {
		padding-inline-start: 3rem;
	}

	#secondary {
		grid-column: 1;
	}

	#primary {
		grid-column: 2;
	}
	
	.wp-block-heading {
		font-size: 1.5rem;
		margin-block-end: 1rem;
	}
	
}


/* Product Details */

.woocommerce-product-gallery__image {
	background: var(--bg-light-200);
}

.flex-control-nav.flex-control-thumbs {
	display: flex;
	gap: 10px;
	margin-block-start: 10px;
}

.flex-control-nav.flex-control-thumbs li {
	border: 1px solid rgb(204, 204, 204);
}

.woocommerce-product-gallery {
	margin-block-end: 2rem;
}

.woocommerce-product-details__short-description {
	color: var(--text-light-200);
}

.single-product-sku {
	color: var(--text-light-200);
	font-size: 0.875rem;

}

.summary .price {
  font-size: 2rem;
  margin-block: 1.5rem;
}

form.cart {
	display: flex;
}

.quantity input {
	width: 60px;
	text-align: center;
	margin-inline-end: 10px;
}

.single-product-main-description {
	margin-block-start: 2rem;
}

.share-buttons {
	display: flex;
	padding-block: 1rem;
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
	margin-block-start: 2rem;
}

.share-buttons p {
	margin-block-end: 0;
	margin-inline-end: 10px;
}

 
.share-buttons .icon-facebook {
	color: blue;
}

.share-buttons a {
	padding-inline: 0.25rem;
	border-radius: 4px;
	transition: background-color 0.3s, color 0.3s;
}

.share-buttons a:hover {
	background-color: blue;
	color: var(--text-light-100);
}


.related.products {
	margin-block: 2.5rem;
}

.woocommerce div.product div.images .woocommerce-product-gallery__trigger {
  background: #fff;
  border: none;
  box-sizing: content-box;
  border-radius: 100%;
  cursor: pointer;
  font-size: 2em;
  height: 36px;
  padding: 0;
  position: absolute;
  right: .5em;
  text-indent: -9999px;
  top: .5em;
  width: 36px;
  z-index: 99;
	display: none;
}




@media (min-width: 768px) {
	.wc-custom-group {
		display: flex;
		gap: 2rem;
	}

	.woocommerce-product-gallery,
	.summary.entry-summary {
		flex: 1;
	}
}	
	

@media (min-width: 1024px) {
	.custom-product-tabs {
		max-inline-size: 928px;
		margin-inline: auto!important;
		margin-block: 5rem!important;
	}
}



.site-layout-grid {
	padding-bottom: 3rem;
}




/* -- About us
------------------------------- */
.about__headline {
	font-size: 1.75rem;
	line-height: 1;
	margin-block: 2rem 1rem;
	font-weight: 500;
}

blockquote {
	font-size: 1.2rem;
	font-style: italic;
	color: var(--text-light-200);
	margin-block-end: 1rem;
}

.about {
	padding-block: 2.5rem;
}

.about__dark {
	background: var(--bg-light-200);
}

.about__image {
	margin-block-end: 1rem;
}

.about li {
	margin-block-end: .5rem;
}


@media (min-width: 1024px) {
	
	.about__content {
		column-count: 2;
		gap: 3rem;
	}
	
}



/* Notice */
.woocommerce-message {
	color: var(--color-blue);
	margin-bottom: 2rem;

    display: flex;
    align-items: center;
    gap: 15px;
}

.woocommerce-message .button {
    margin-left: auto;
}


.single-product-inu {
	margin-top: 1.5rem;
}

.dermatologisch-getestet {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 12px;
}

.dermatologisch-getestet img {
    width: 18px;
    height: 18px;
    object-fit: contain;
}








