
/* ============================================ */
/* MODERN BAKERY SHOP STYLES V3 */
/* Warm & Friendly Theme - Clean & Accessible */
/* Keine importierten Schriften - System-Fonts */
/* ============================================ */
@import url('gridism.css');

:root {
	/* Warm & Friendly Color Palette */
	--bg-primary: #fffef7;
	--bg-secondary: #fef9e6;
	--bg-card: #ffffff;
	--bg-elevated: #fef7e8;
	--border-soft: #f0e4c8;
	--border-medium: #e5d5b0;
	/* Warm Accent Colors */
	--warm-brown: #8b5a2b;
	--warm-terracotta: #c17b4c;
	--warm-gold: #d4a373;
	--warm-honey: #e9b35f;
	--warm-caramel: #b97f44;
	--warm-sand: #f5e6d3;
	/* Fresh Accent Colors */
	--fresh-green: #6b8c42;
	--fresh-mint: #9bbf7a;
	--fresh-olive: #7d6b3c;
	/* Status Colors - Accessible */
	--success: #2e7d32;
	--success-bg: #e8f5e9;
	--warning: #ed6c02;
	--warning-bg: #fff4e5;
	--error: #c62828;
	--error-bg: #ffebee;
	--info: #0288d1;
	--info-bg: #e1f5fe;
	/* Text Colors */
	--text-dark: #2c2418;
	--text-soft: #5a4a32;
	--text-muted: #8b765c;
	--text-light: #b8a27a;
	/* Effects */
	--shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.04), 0 1px 2px rgba(0, 0, 0, 0.02);
	--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.02);
	--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.05), 0 4px 6px -2px rgba(0, 0, 0, 0.02);
	--shadow-hover: 0 20px 25px -5px rgba(0, 0, 0, 0.05), 0 10px 10px -5px rgba(0, 0, 0, 0.01);
	--radius-sm: 0.5rem;
	--radius-md: 1rem;
	--radius-lg: 1.5rem;
	/* Transitions */
	--transition-fast: all 0.2s ease;
	--transition-smooth: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* --- Base Styles --- */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	background: var(--bg-primary);
	color: var(--text-dark);
	line-height: 1.6;
}

/* --- Typography Hierarchie --- */
h1,
h2,
h3,
h4,
h5,
h6 {
	font-weight: 600;
	line-height: 1.3;
	color: var(--text-dark);
	letter-spacing: -0.01em;
}

h1 {
	font-size: 2.5rem;
	font-weight: 700;
	margin-bottom: 1.5rem;
	background: linear-gradient(135deg, var(--warm-brown) 0%, var(--warm-terracotta) 100%);
	background-clip: text;
	-webkit-background-clip: text;
	color: transparent;
}

h2 {
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 1.25rem;
	color: var(--warm-brown);
}

h3 {
	font-size: 1.5rem;
	font-weight: 600;
	margin-bottom: 1rem;
	color: var(--warm-terracotta);
}

h4 {
	font-size: 1.25rem;
	font-weight: 600;
	margin-bottom: 0.75rem;
	color: var(--text-dark);
}

.mod_bakery_h_f {
	background: var(--bg-card);
	border-radius: var(--radius-lg);
	padding: 2rem;
	margin-bottom: 2rem;
	box-shadow: var(--shadow-sm);
	border: 1px solid var(--border-soft);
}

.mod_bakery_ordernum_f {
	font-weight: 600;
	color: var(--warm-terracotta);
	background: var(--bg-secondary);
	padding: 0.375rem 1rem;
	border-radius: 100px;
	display: inline-block;
	font-size: 0.875rem;
	border: 1px solid var(--border-soft);
}

.mod_bakery_hr_f {
	display: block;
	height: 2px;
	border: 0;
	background: linear-gradient(90deg, transparent, var(--border-soft), var(--warm-gold), var(--border-soft), transparent);
	margin: 2rem 0;
}

/* --- Product Grid (Main Page) --- */
.mod_bakery_main {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 2rem;
	padding: 0.5rem 0;
}

.mod_bakery_main_div {
	background: var(--bg-card);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: var(--transition-smooth);
	border: 1px solid var(--border-soft);
	box-shadow: var(--shadow-sm);
}

.mod_bakery_main_div:hover {
	transform: translateY(-6px);
	border-color: var(--warm-gold);
	box-shadow: var(--shadow-hover);
}

.mod_bakery_main_thumb_f {
	text-align: center;
	background: var(--bg-secondary);
	padding: 2rem;
	position: relative;
}

.mod_bakery_main_img_f {
	max-width: 100%;
	height: auto;
	transition: var(--transition-smooth);
}

.mod_bakery_main_div:hover .mod_bakery_main_img_f {
	transform: scale(1.03);
}

.mod_bakery_main_div_cart_bt_f {
	padding: 1.5rem;
	text-align: center;
	border-top: 1px solid var(--border-soft);
	background: var(--bg-card);
}

.mod_bakery_main_title_f {
	font-size: 1.25rem;
	font-weight: 700;
	margin: 0.75rem 0 0.5rem;
	color: var(--text-dark);
	text-decoration: none;
	display: block;
	transition: var(--transition-fast);
}

.mod_bakery_main_title_f:hover {
	color: var(--warm-terracotta);
}

/* Stock Status Badges */
.mod_bakery_main_in_stock_f,
.mod_bakery_main_short_of_stock_f,
.mod_bakery_main_out_of_stock_f {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 600;
	padding: 0.25rem 0.875rem;
	border-radius: 100px;
	margin-top: 0.5rem;
}

.mod_bakery_main_in_stock_f {
	background: var(--success-bg);
	color: var(--success);
}

.mod_bakery_main_short_of_stock_f {
	background: var(--warning-bg);
	color: var(--warning);
}

.mod_bakery_main_out_of_stock_f {
	background: var(--error-bg);
	color: var(--error);
}

/* Price Styling */
.mod_bakery_main_price_f {
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--warm-brown);
	margin: 0.75rem 0;
}

/* Input Fields */
.mod_bakery_main_input_f {
	width: 80px;
	text-align: center;
	padding: 0.625rem;
	background: var(--bg-primary);
	border: 1px solid var(--border-soft);
	border-radius: var(--radius-sm);
	color: var(--text-dark);
	font-size: 0.875rem;
	transition: var(--transition-fast);
}

.mod_bakery_main_input_f:focus {
	outline: none;
	border-color: var(--warm-gold);
	box-shadow: 0 0 0 3px rgba(212, 163, 115, 0.1);
}

/* --- Item Page (Detail View) --- */
.mod_bakery_item {
	background: var(--bg-card);
	border-radius: var(--radius-lg);
	padding: 2.5rem;
	border: 1px solid var(--border-soft);
	box-shadow: var(--shadow-sm);
}

.mod_bakery_item_table_f {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0 1.25rem;
}

.mod_bakery_item_title_f {
	font-size: 2rem;
	font-weight: 700;
	color: var(--warm-brown);
	margin-bottom: 1rem;
}

.mod_bakery_item_price_f {
	font-size: 2rem;
	font-weight: 700;
	color: var(--warm-terracotta);
}

.mod_bakery_item_full_desc_f {
	margin: 1.5rem 0;
	padding: 1.5rem;
	background: var(--bg-secondary);
	border-radius: var(--radius-md);
	line-height: 1.7;
	border-left: 4px solid var(--warm-gold);
	color: var(--text-soft);
}

.mod_bakery_item_input_f {
	width: 80px;
	padding: 0.625rem;
	background: var(--bg-primary);
	border: 1px solid var(--border-soft);
	border-radius: var(--radius-sm);
	color: var(--text-dark);
	text-align: center;
	display: none;
}

/* --- Shopping Cart --- */
.mod_bakery_cart {
	background: var(--bg-card);
	border-radius: var(--radius-lg);
	padding: 2rem;
	border: 1px solid var(--border-soft);
	box-shadow: var(--shadow-sm);
	overflow-x: auto;
}

.mod_bakery_cart table {
	width: 100%;
	border-collapse: collapse;
}

.mod_bakery_cart th {
	text-align: left;
	padding: 1rem 1rem;
	background: var(--bg-secondary);
	font-weight: 600;
	color: var(--text-dark);
	border-bottom: 2px solid var(--border-soft);
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

.mod_bakery_cart td {
	padding: 1.25rem 1rem;
	border-bottom: 1px solid var(--border-soft);
	vertical-align: middle;
	color: var(--text-soft);
}

.mod_bakery_cart_row:nth-child(even) {
	background-color: var(--bg-secondary);
}

.mod_bakery_cart_td_quantity_f {
	white-space: nowrap;
}

.mod_bakery_cart_td_quantity_f a {
	display: inline-block;
	margin: 0 0.375rem;
	transition: var(--transition-fast);
	opacity: 0.6;
}

.mod_bakery_cart_td_quantity_f a:hover {
	opacity: 1;
	transform: scale(1.1);
}

.mod_bakery_cart_td_quantity_f img {
	width: 24px;
	height: 24px;
	border: none;
}

/* Cart Totals */
.mod_bakery_sum {
	margin-top: 2rem;
	border-top: 2px solid var(--border-soft);
	padding-top: 2rem;
}

.mod_bakery_cart_subtotal_f,
.mod_bakery_cart_shipping_f,
.mod_bakery_cart_tax_f,
.mod_bakery_cart_total_f {
	display: flex;
	justify-content: flex-end;
	align-items: baseline;
	gap: 1.5rem;
	padding: 0.5rem 0;
}

.mod_bakery_cart_total_f {
	font-size: 1.25rem;
	font-weight: 800;
	color: var(--warm-brown);
	border-top: 2px solid var(--border-soft);
	margin-top: 0.75rem;
	padding-top: 1.25rem;
}

/* --- Checkout Form --- */
.mod_bakery_form {
	background: var(--bg-card);
	border-radius: var(--radius-lg);
	padding: 2.5rem;
	border: 1px solid var(--border-soft);
	box-shadow: var(--shadow-sm);
}

.mod_bakery_form_label_f {
	font-weight: 600;
	margin-bottom: 0.5rem;
	display: block;
	color: var(--text-dark);
	font-size: 0.875rem;
}

.mod_bakery_form_input_f {
	width: 100%;
	padding: 0.875rem;
	background: var(--bg-primary);
	border: 1px solid var(--border-soft);
	border-radius: var(--radius-sm);
	color: var(--text-dark);
	font-size: 0.9375rem;
	transition: var(--transition-fast);
}

.mod_bakery_form_input_f:focus {
	outline: none;
	border-color: var(--warm-gold);
	box-shadow: 0 0 0 3px rgba(212, 163, 115, 0.1);
}

/* --- Payment Section --- */
.mod_bakery_agree_f {
	background: var(--bg-secondary);
	border: 1px solid var(--border-soft);
	border-radius: var(--radius-md);
	padding: 1.5rem;
	margin: 1.5rem 0;
}

.mod_bakery_err_agree_f {
	border-color: var(--error);
	background-color: var(--error-bg);
}

.mod_bakery_pay_method_f {
	font-weight: 600;
	margin: 1.5rem 0 1rem;
	color: var(--text-dark);
}

.mod_bakery_pay_td_f {
	padding: 0.75rem;
	color: var(--text-soft);
}

/* --- Modern Buttons --- */
input[type="submit"],
.mod_bakery_bt_add_f,
.mod_bakery_bt_update_f,
.mod_bakery_bt_continue_f,
.mod_bakery_bt_order_f,
.mod_bakery_bt_cancel_f {
	background: orange;
	color: white;
	border: none;
	padding: 0.75rem 1.75rem;
	border-radius: 7px;
	font-weight: 600;
	font-size: 0.875rem;
	cursor: pointer;
	transition: var(--transition-smooth);
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
}

input[type="submit"]:hover,
.mod_bakery_bt_add_f:hover,
.mod_bakery_bt_update_f:hover,
.mod_bakery_bt_continue_f:hover,
.mod_bakery_bt_order_f:hover {
	background: var(--warm-terracotta);
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

.mod_bakery_bt_cancel_f {
	background: var(--text-muted);
}

.mod_bakery_bt_cancel_f:hover {
	background: var(--text-soft);
	transform: translateY(-2px);
}

.mod_bakery_bt_buy_f {
	width: 100%;
	background: var(--fresh-green);
	font-size: 1rem;
	font-weight: 700;
	padding: 1rem;
}

.mod_bakery_bt_buy_f:hover {
	background: var(--fresh-mint);
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

/* --- Messages (Success/Error) --- */
.mod_bakery_success_f,
.mod_bakery_error_f,
.mod_bakery_information_f {
	border-radius: var(--radius-md);
	padding: 1rem 1rem 1rem 2.5rem;
	margin-bottom: 1.5rem;
	position: relative;
	border-left: 4px solid;
}

.mod_bakery_success_f {
	background: var(--success-bg);
	border-left-color: var(--success);
	color: var(--success);
}

.mod_bakery_error_f {
	background: var(--error-bg);
	border-left-color: var(--error);
	color: var(--error);
}

.mod_bakery_information_f {
	background: var(--info-bg);
	border-left-color: var(--info);
	color: var(--info);
}

/* --- Mini Cart --- */
#mod_bakery_mc_div_f {
	background: var(--bg-card);
	border-radius: var(--radius-md);
	padding: 1.25rem;
	border: 1px solid var(--border-soft);
	box-shadow: var(--shadow-sm);
	position: sticky;
	top: 1rem;
	width: 100%;
	max-width: 320px;
}

.mod_bakery_mc_h2_cart_f {
	font-size: 1.125rem;
	font-weight: 700;
	margin-bottom: 1rem;
	padding-bottom: 0.75rem;
	border-bottom: 2px solid var(--warm-gold);
	color: var(--warm-brown);
}

.mod_bakery_mc_total_f {
	font-weight: 800;
	color: var(--warm-terracotta);
}

/* --- Responsive Adjustments --- */
@media (max-width: 768px) {
	.mod_bakery_main {
		grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
		gap: 1.25rem;
	}

	.mod_bakery_cart table,
	.mod_bakery_cart thead,
	.mod_bakery_cart tbody,
	.mod_bakery_cart tr,
	.mod_bakery_cart td {
		display: block;
	}

	.mod_bakery_cart th {
		display: none;
	}

	.mod_bakery_cart td {
		padding: 0.875rem;
		text-align: right;
		position: relative;
		padding-left: 45%;
	}

	.mod_bakery_cart td:before {
		content: attr(data-label);
		position: absolute;
		left: 1rem;
		width: 40%;
		font-weight: 600;
		text-align: left;
		color: var(--text-dark);
	}

	.mod_bakery_form_input_f {
		width: 100%;
	}

	.mod_bakery_h_f,
	.mod_bakery_form,
	.mod_bakery_cart,
	.mod_bakery_item {
		padding: 1.25rem;
	}

	h1 {
		font-size: 1.75rem;
	}

	h2 {
		font-size: 1.5rem;
	}

	.mod_bakery_item_title_f {
		font-size: 1.5rem;
	}
}

/* --- Required Star --- */
.mod_bakery_required_star {
	color: var(--error);
	font-weight: 700;
	margin-left: 0.25rem;
}

/* --- Print Styles --- */
@media print {

	.mod_bakery_bt_add_f,
	.mod_bakery_bt_update_f,
	.mod_bakery_bt_continue_f,
	.mod_bakery_bt_order_f {
		display: none;
	}

	body {
		background: white;
		color: black;
	}

	.mod_bakery_cart,
	.mod_bakery_h_f {
		background: white;
		border: 1px solid #ddd;
		box-shadow: none;
	}
}

/* --- Additional Details --- */
/* Product Badge (optional) */
.mod_bakery_main_thumb_f::after {
	content: '';
	display: none;
}

/* Form Select Styling */
select.mod_bakery_main_select_f,
select.mod_bakery_item_select_f {
	padding: 0.625rem;
	background: var(--bg-primary);
	border: 1px solid var(--border-soft);
	border-radius: var(--radius-sm);
	color: var(--text-dark);
	font-size: 0.875rem;
	cursor: pointer;
}

/* Link Styling */
a {
	color: var(--warm-terracotta);
	text-decoration: none;
	transition: var(--transition-fast);
}

a:hover {
	color: var(--warm-brown);
}

/* Table Cell Alignment */
.mod_bakery_cart_td_thumb_f,
.mod_bakery_cart_th_thumb_f {
	text-align: center;
}

.mod_bakery_cart_td_price_f,
.mod_bakery_cart_td_sum_f,
.mod_bakery_cart_th_price_f,
.mod_bakery_cart_th_sum_f {
	text-align: right;
}