/* --- 1. Header-Alignment --- */
#shoppingcartHeader .row > div {
	display: flex;
	align-items: center;
}

#shoppingcartHeader .col-lg-3.text-right {
	justify-content: flex-end;
}

/* --- 2. Positionen: Zwischensumme immer ganz rechts --- */
#shoppingcartPositions .shoppingcart-position {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
}

#shoppingcartPositions .product-image {
	margin-right: 1.5rem;
}

#shoppingcartPositions .product {
	flex: 1 1 auto;
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: flex-start;
	gap: 2rem;
}

#shoppingcartPositions .details-and-qty {
	flex: 1 1 0;
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}

#shoppingcartPositions .summary-area {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	min-width: 120px;
	justify-content: flex-start;
}

#shoppingcartPositions .subtotal {
	font-size: 1.18rem;
	font-weight: 600;
	color: #3f583b;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	white-space: nowrap;
}

/* --- 3. Preis + € in einer Zeile, sauber ausgerichtet --- */
#shoppingcartPositions .price,
#shoppingcartPositions .subtotal {
	display: flex;
	align-items: center;
	gap: 0.4rem;
}

#shoppingcartPositions .price .currency-sign,
#shoppingcartPositions .subtotal .currency-sign {
	font-size: 1.09em;
	font-weight: 500;
	margin-left: 2px;
}

/* --- Trash Button vertikal mittig zur Zeile ausrichten --- */
#shoppingcartPositions .trash {
	align-self: center;
	margin-left: 1.2rem;
}

/* --- Responsive Anpassung für Mobile --- */
@media (max-width: 767.98px) {
	#shoppingcartPositions .shoppingcart-position {
		flex-direction: column;
		align-items: stretch;
	}

	#shoppingcartPositions .product {
		flex-direction: column;
		gap: 0.2rem;
		align-items: flex-start;
	}

	#shoppingcartPositions .summary-area {
		align-items: flex-end;
		justify-content: flex-end;
		margin-top: 0.6rem;
	}
}

#coupon {
	font-size: large;
}

#coupon .form-control {
	border-radius: 5px;
	padding: 1rem;
	font-size: 1.5rem;
	line-height: 2rem;
	color: #000;
	text-transform: uppercase;
}

#coupon .form-control::-webkit-input-placeholder {
	/* Edge */
	color: #41693d !important;
}

#coupon .form-control:-ms-input-placeholder {
	/* Internet Explorer 10-11 */
	color: #41693d !important;
}

#coupon .form-control::placeholder {
	color: #41693d !important;
}

#shoppingcartHeader {
	color: #000;
	font-size: larger;
	border-bottom: #034059 1px solid;
	padding-bottom: 2rem;
}

body.dark-mode #shoppingcartHeader {
	color: #fff;
	background-color: transparent;
	font-size: larger;
	border-bottom: #034059 1px solid;
	padding-bottom: 2rem;
}

body.dark-mode #shoppingcartSubtotal {
	background: #1f1f1f;
}

/* Shoppingcart Subtotal */
#shoppingcartSubtotal {
	border: 1px solid #000;
	margin-bottom: 20px;
}

#shoppingcartSubtotal .box {
	padding: 1rem;
	border-bottom: 1px solid #000;
	font-size: large;
	line-height: 40px;
	min-height: 84.84px;
}

/* Shoppingcartpositions */
#shoppingcartPositions .shoppingcart-position {
	margin: 0px auto;

	color: #41693d;

	flex-direction: row;
	flex-wrap: nowrap;
	align-content: center;
	justify-content: flex-start;
	align-items: baseline;
	padding: 25px 20px 10px 0;
	border-bottom: 2px solid #c5c5c5;
}

/* #shoppingcartPositions > .shoppingcart-position:last-child {
		border-bottom: 0;
	} */

#shoppingcartPositions .shoppingcart-position .product {
	min-height: auto;
}

#shoppingcartPositions .shoppingcart-position .name {
	font-size: large;
}

#shoppingcartPositions .shoppingcart-position .price {
	font-size: 20px;
	font-weight: normal;
	flex-wrap: nowrap;
}

#shoppingcartPositions .shoppingcart-position img {
	max-width: 200px;
}

#shoppingcartPositions .shoppingcart-position .product {
	width: 80%;
}

#shoppingcartPositions .shoppingcart-position .right {
	text-align: right;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

#shoppingcartPositions .shoppingcart-position .left {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

#shoppingcartPositions .shoppingcart-position .trashbox {
	height: 45px;
}

#shoppingcartPositions .shoppingcart-position .trash,
#shoppingcartPositions .trash-coupon {
	font-size: 30px;
	cursor: pointer;
	right: 0;
}

#shoppingcartPositions .shoppingcart-position .subtotal {
	text-align: right;
}

#shoppingcartPositions .quantity {
	margin: 0 0 20px 0;
	width: 150px;
	padding: 5px;
	display: flex;
	color: #034059;
	border: 1px solid #ccd9de;
	border-radius: 5%;
	margin-right: auto;
	flex-direction: row;
	flex-wrap: nowrap;
	align-content: center;
	justify-content: space-evenly;
	align-items: baseline;
}

.btn-checkout {
	background-color: #41693d !important;
}

/* --- Container und Grundabstände --- */
#shoppingcart {
	padding-bottom: 2rem;
}

#shoppingcartHeader {
	color: #333;
	font-size: 1.15rem;
	border-bottom: 2px solid #ececec;
	padding-bottom: 1rem;
	margin-bottom: 0.7rem;
	background: #fff;
}

#shoppingcart h1 {
	font-size: 2.1rem;
	letter-spacing: 0.01em;
}

/* --- Responsives Grid --- */
@media (max-width: 991.98px) {
	#shoppingcart .col-lg-9 {
		order: 2;
	}
	#shoppingcart .col-lg-3 {
		order: 1;
		margin-bottom: 2.5rem;
	}
}
@media (max-width: 767.98px) {
	body.dark-mode #shoppingcartPositions * {
		color: #fff;
	}
}

/* --- Shoppingcart Position Items --- */
#shoppingcartPositions .shoppingcart-position {
	border-radius: 14px;
	background: #fcfcfa;
	box-shadow: 0 3px 18px rgba(220, 180, 110, 0.05);
	padding: 1.4rem 1rem 1.2rem 1rem;
	margin-bottom: 1.2rem;
	border-bottom: none;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	transition: box-shadow 0.13s;
}

#shoppingcartPositions .shoppingcart-position:hover {
	box-shadow: 0 7px 32px rgba(190, 157, 127, 0.11);
}

#shoppingcartPositions .product-image img {
	max-width: 110px;
	border-radius: 9px;
	background: #f1ece8;
	box-shadow: 0 1px 7px rgba(220, 180, 110, 0.07);
}

/* --- Desktop Zeile: Flex-Row Aufbau --- */
@media (min-width: 768px) {
	#shoppingcartPositions .shoppingcart-position {
		flex-direction: row;
		align-items: flex-start;
	}
	#shoppingcartPositions .product-image {
		margin-right: 1.2rem;
		flex-shrink: 0;
	}
	#shoppingcartPositions .product {
		flex: 1 1 0%;
	}
}

/* --- Name, Info, Preis --- */
#shoppingcartPositions .name {
	font-size: 1.14rem;
	font-weight: 500;
	color: #333;
}
#shoppingcartPositions .amount {
	font-size: 0.93rem;
	color: #a18d7b;
	font-weight: 400;
	margin-top: 0.1rem;
}
#shoppingcartPositions .price {
	font-size: 1.21rem;
	color: #314634;
	font-weight: bold;
}
#shoppingcartPositions .baseprice {
	font-size: 0.91rem;
	color: #ae936e;
	margin-top: 2px;
}

#shoppingcartPositions .subtotal {
	color: #b69058;
	font-size: 1.14rem;
	font-weight: 600;
}

/* --- Quantity Input --- */
#shoppingcartPositions .quantity {
	display: flex;
	align-items: center;
	justify-content: start;
	border: 1px solid #e4d9cc;
	border-radius: 8px;
	width: 114px;
	overflow: hidden;
	margin: 0.5rem 0 0.5rem 0;
	background: #f6f2ed;
}

#shoppingcartPositions .quantity .minus,
#shoppingcartPositions .quantity .plus {
	font-size: 1.3rem;
	cursor: pointer;
	width: 2.2rem;
	height: 2.2rem;
	text-align: center;
	color: #be9d7f;
	background: transparent;
	border: none;
	user-select: none;
}

#shoppingcartPositions .quantity input[type='number'] {
	width: 2.5rem;
	text-align: center;
	font-size: 1.08rem;
	border: none;
	background: transparent;
	color: #555;
	font-weight: 500;
	outline: none;
}

/* --- Remove Button --- */
#shoppingcartPositions .trash,
#shoppingcartPositions .trash-coupon {
	color: #cf7562;
	font-size: 2rem;
	cursor: pointer;
	margin-left: 1.4rem;
	transition: color 0.13s;
}
#shoppingcartPositions .trash:hover,
#shoppingcartPositions .trash-coupon:hover {
	color: #be2233;
}

/* --- Mobile Anpassungen --- */
@media (max-width: 767.98px) {
	#shoppingcartPositions .shoppingcart-position {
		padding: 1rem 0.5rem;
		border-radius: 9px;
		margin-bottom: 1.1rem;
	}
	#shoppingcartHeader {
		font-size: 1rem;
		padding: 0.6rem 0.2rem;
	}
	#shoppingcartPositions .product-image img {
		max-width: 90px;
	}
	#shoppingcartPositions .price,
	#shoppingcartPositions .subtotal {
		font-size: 1.05rem;
	}
}

/* --- Coupon Feld --- */
#coupon {
	background: #f7f4f1;
	border-radius: 8px;
	padding: 1.2rem 1rem 0.8rem 1rem;
	margin-top: 2.3rem;
	box-shadow: 0 2px 8px rgba(220, 180, 110, 0.07);
}

#coupon a[data-toggle='collapse'] {
	color: #be9d7f;
	font-weight: 600;
	letter-spacing: 0.02em;
}

#coupon .form-control {
	border-radius: 6px;
	padding: 0.75rem;
	font-size: 1.12rem;
	line-height: 1.7rem;
	color: #a67d5e;
	background: #fff6f2;
}
#coupon .btn {
	margin-top: 0.5rem;
}

/* --- Subtotal Box --- */
#shoppingcartSubtotal {
	background: #d7c4b6;
	border-radius: 12px;
	box-shadow: 0 2px 12px rgba(190, 157, 127, 0.1);
	border: none !important;
	padding: 1.6rem 1.4rem 1.7rem 1.4rem;
	font-size: 1.1rem;
	margin-bottom: 1.4rem;
}

#shoppingcartSubtotal .box {
	border-bottom: 1px solid #ebd5c0;
	padding-bottom: 0.5rem;
	margin-bottom: 0.5rem;
	background: none;
}

#shoppingcartSubtotal .box:last-child {
	border-bottom: none;
}

#shoppingcartSubtotal .btn {
	background: #be9d7f;
	border: none;
	color: #fff;
	font-weight: 600;
	margin-top: 1.1rem;
}

#shoppingcartSubtotal .float-right {
	float: right;
}

@media (max-width: 767.98px) {
	#shoppingcartSubtotal {
		padding: 1.2rem 0.6rem 1.3rem 0.6rem;
		margin-top: 1.5rem;
	}
}

.clearfix-both {
	clear: both;
}

/* --- Teilen Buttons (Share-Section) --- */
#shoppingcart .card-body .btn {
	font-size: 1rem;
	border-radius: 7px;
	background: #e8e3df;
	color: #53412e;
	font-weight: 500;
	border: 1px solid #ddd0be;
	margin: 0.2rem 0.4rem 0.2rem 0;
	transition: background 0.14s;
}
#shoppingcart .card-body .btn:hover {
	background: #ead6bb;
	color: #2d1d0b;
}

/* --- Login Color Mode --- */
body.login-color #shoppingcartHeader {
	color: #000;
	border-bottom: 2px solid #c08693;
}
body.login-color #shoppingcartPositions .shoppingcart-position {
	background: #fff4f7;
	box-shadow: 0 3px 18px rgba(234, 192, 200, 0.07);
}
body.login-color #shoppingcartPositions .price,
body.login-color #shoppingcartSubtotal .box,
body.login-color #shoppingcartSubtotal .btn {
	color: #aa4e66;
}
body.login-color #shoppingcartSubtotal {
	background: #fbeaf2;
}
body.login-color #coupon {
	background: #fbeaf2;
}
body.login-color #coupon a[data-toggle='collapse'] {
	color: #aa4e66;
}
body.login-color #shoppingcartSubtotal .btn {
	background: #e8c5c9;
	color: #741b39;
}
body.login-color #shoppingcartSubtotal .btn:hover {
	background: #d09ba7;
}
#shoppingcartSubtotal .float-right,
#shoppingcartSubtotal .text-right,
#shoppingcartSubtotal span.text-right,
#shoppingcartSubtotal strong {
	font-size: 0.97rem !important;
	white-space: nowrap;
	line-height: 1.5;
}

#shoppingcartSubtotal .currency-sign {
	font-size: 1em;
	font-weight: 500;
	margin-left: 2px;
}

#shoppingcartSubtotal .float-right,
#shoppingcartSubtotal .text-right,
#shoppingcartSubtotal span.text-right,
#shoppingcartSubtotal strong,
#shoppingcartSubtotal .total-amount,
#shoppingcartSubtotal .nowrap {
	font-size: 1rem !important;
	font-weight: 600;
	white-space: nowrap;
	letter-spacing: 0;
	line-height: 1.4;
	display: inline-block;
}

#shoppingcartSubtotal .total-amount {
	font-size: 1.15rem !important;
	font-weight: 800;
	white-space: nowrap;
	display: inline-block;
	vertical-align: middle;
}

#shoppingcartSubtotal strong .currency-sign,
#shoppingcartSubtotal .total-amount .currency-sign {
	font-size: 1.09em;
	font-weight: 600;
	margin-left: 2px;
}

#shoppingcartSubtotal .float-right {
	white-space: nowrap;
}

#shoppingcartSubtotal .box {
	line-height: 1.3;
}

/* Optional: Für kleinere Screens noch kleiner */
@media (max-width: 500px) {
	#shoppingcartSubtotal .total-amount,
	#shoppingcartSubtotal .float-right {
		font-size: 0.97rem !important;
	}
}

#shoppingcart {
	display: flex;
	align-items: stretch;
	/* sorgt dafür, dass beide Spalten die gleiche Höhe einnehmen */
	min-height: 100%;
}

#shoppingcart > .col-lg-9,
#shoppingcart > .col-lg-3 {
	display: flex;
	flex-direction: column;
	align-items: stretch;
}

#shoppingcartSubtotal {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	/* sorgt dafür, dass die Box die volle Höhe einnimmt */
	height: 100%;
	min-height: 100%;
}

@media (min-width: 992px) {
	#shoppingcartSubtotal {
		position: sticky;
		top: 30px;
	}
}
