/* General Styles */
body {
	font-family: 'Inter', Arial, sans-serif;
	color: #222222;
	box-sizing: border-box;
	background-color: #fff;
}

/* Order Form Styling */
#breakfast-order-form {
	max-width: 800px;
	margin: 0 auto;
	padding: 20px;
	background-color: #fff;
	box-shadow: 0 2px 20px rgba(177, 87, 87, 0.1);
}

#breakfast-order-form h3 {
	font-size: 18px;
	margin-bottom: 24px;
	color: #222;
	position: relative;
	text-align: left;
}

#breakfast-order-form h3::after {
	content: '';
	position: absolute;
	bottom: -8px;
	left: 0;
	width: 40px;
	height: 2px;
	background-color: #b15757;
}

#breakfast-order-form label {
	display: flex;
	align-items: center;
	gap: 5px;
	margin-bottom: 8px;
	font-size: 14px;
	color: #222;
}

#breakfast-order-form input[type="text"],
#breakfast-order-form input[type="number"],
#breakfast-order-form select,
textarea {
	width: 100%;
	padding: 12px;
	margin-bottom: 15px;
	border: 1px solid #222;
	font-size: 14px;
	max-width: 100%;
	box-sizing: border-box;
	background-color: #fff;
	transition: border-color 0.3s ease;
	font-family: 'Inter', Arial, sans-serif;
	border-radius: 0;
}

#breakfast-order-form input[type="text"]:focus,
#breakfast-order-form input[type="number"]:focus,
#breakfast-order-form select:focus,
textarea:focus {
	outline: none;
	border-color: #b15757;
}

.e-food-cta-wrapper {
	text-align: center;
}

.e-food-cta-wrapper p {
	margin-block: 1em;
	font-size: clamp(1.125rem, 1.125rem + ((1vw - 0.2rem) * 0.392), 1.375rem);
}

.e-food-cta-wrapper a {
	text-decoration: none;
	display: inline;
}

#breakfast-order-form button,
.e-food-cta-wrapper a {
	width: 100%;
	padding: 12px;
	background-color: #b15757;
	color: white;
	font-size: 16px;
	border: none;
	cursor: pointer;
	transition: 0.3s ease-in-out;
	font-weight: 400;
    padding-block: 12px !important;
	border-radius: 0;
}

#breakfast-order-form button:hover,
.e-food-cta-wrapper a:hover {
	background-color: #fff;
	color: #b15757;
	outline: 1px solid #b15757;
}

/* Response Message */
#order-response {
	margin-top: 20px;
	font-size: 16px;
	text-align: center;
}

#order-response p {
	margin: 0;
	padding: 10px;
	background-color: #eaf9ea;
	color: #4caf50;
}

/* Admin Order List Styling */
#order-list {
	margin-top: 30px;
}

.order-item {
	background-color: #fff;
	padding: 15px;
	margin-bottom: 15px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.order-item h3 {
	font-size: 16px;
	color: #333;
}

.order-item p {
	font-size: 14px;
	color: #555;
}

.order-item button {
	padding: 8px 16px;
	background-color: #4caf50;
	color: white;
	border: none;
	cursor: pointer;
	transition: background-color 0.3s ease;
}

.order-item button:hover {
	background-color: #45a049;
}

.order-item.completed {
	background-color: #f0f9f0;
	border: 1px solid #c8e6c9;
}

.order-item.completed p {
	font-weight: bold;
	color: #4caf50;
}

.order-item.completed button {
	background-color: #8bc34a;
	cursor: not-allowed;
}

.order-item.completed button:hover {
	background-color: #8bc34a;
}

.package-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
	gap: 20px;
	margin-bottom: 20px;
	align-items: start;

	@media (max-width: 350px) {
		grid-template-columns: repeat(auto-fill, minmax(100%, 1fr));
	}
}

.package-card {
	display: flex;
	flex-wrap: wrap;
	background: #fff;
	border: 1px solid #222;
	padding: 15px;
	box-shadow: 0 4px 8px rgba(177, 87, 87, 0.05);
	transition: 0.3s ease-in-out;
}

.package-card:hover {
	box-shadow: 0 6px 15px rgba(0, 0, 0, 0.15);
}

.package-image {
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}

.package-image img {
	height: auto;
	max-width: 100%;
	aspect-ratio: 150 / 150;
	max-height: 250px;
	width: 100%;
	object-fit: cover;
}

.package-details {
	margin-bottom: 15px;
}

.package-details h4 {
	font-size: 18px;
	color: #333;
	margin-bottom: 10px;
	margin-top: 0;
}

.package-description {
	display: -webkit-box;
	-webkit-line-clamp: 3;
	/* Limit to 3 lines */
	-webkit-box-orient: vertical;
	overflow: hidden;
	transition: max-height 1.3s ease-in-out;
	font-size: 14px;
	text-align: left;
}

.package-description p {
    margin-bottom: 1em;
}

.package-description.expanded {
	-webkit-line-clamp: unset;
	overflow: visible;
}

.package-description ul,
.package-description ol {
	margin-block: 0;
	padding-left: 1rem;
}

.package-details .toggle-description {
    all: unset;
    text-align: left;
	background: none;
    text-decoration: underline;
    border: none;
    cursor: pointer;
    font-size: 14px;
    margin-top: 5px;
    display: block;
    color: #923c3b;
}

.package-selection {
	max-width: 100%;
	width: 100%;
}

.package-selection label {
	font-size: 14px;
	cursor: pointer;
}

.package-quantity {
	margin-top: 10px;
}

.package-quantity input {
	width: 60px;
	padding: 5px;
	font-size: 14px;
}

button {
	background-color: #b15757;
	color: #fff;
	border: 1px solid #b15757;
	padding: 12px 20px;
	font-size: 16px;
	cursor: pointer;
	transition: 0.3s ease-in-out;
}

button:hover {
	background-color: #fff;
	color: #b15757;
}

#order-response {
	text-align: center;
	margin-top: 20px;
}

.ios-checkbox {
	--checkbox-size: 16px;
	--checkbox-color: #222;
	--checkbox-bg: #f3e2e2;
	--checkbox-border: #c65642;

	position: relative;
	display: inline-block;
	cursor: pointer;
	user-select: none;
	-webkit-tap-highlight-color: transparent;
}

.ios-checkbox input {
	display: none;
}

.checkbox-wrapper {
	position: relative;
	width: var(--checkbox-size);
	height: var(--checkbox-size);
	border-radius: 4px;
	transition: transform 0.2s ease;
}

.checkbox-bg {
	position: absolute;
	inset: 0;
	border-radius: 4px;
	border: 2px solid var(--checkbox-border);
	background: white;
	transition: all 0.2s ease;
}

.checkbox-icon {
	position: absolute;
	inset: 0;
	margin: auto;
	width: 80%;
	height: 80%;
	color: white;
	transform: scale(0);
	transition: all 0.2s ease;
}

.check-path {
	stroke-dasharray: 40;
	stroke-dashoffset: 40;
	transition: stroke-dashoffset 0.3s ease 0.1s;
}

/* Checked State */
.ios-checkbox input:checked+.checkbox-wrapper .checkbox-bg {
	background: var(--checkbox-color);
	border-color: var(--checkbox-color);
}

.ios-checkbox input:checked+.checkbox-wrapper .checkbox-icon {
	transform: scale(1);
}

.ios-checkbox input:checked+.checkbox-wrapper .check-path {
	stroke-dashoffset: 0;
}

/* Hover Effects */
.ios-checkbox:hover .checkbox-wrapper {
	transform: scale(1.05);
}

/* Active Animation */
.ios-checkbox:active .checkbox-wrapper {
	transform: scale(0.95);
}

/* Focus Styles */
.ios-checkbox input:focus+.checkbox-wrapper .checkbox-bg {
	box-shadow: 0 0 0 4px var(--checkbox-bg);
}

/* Color Themes */
.ios-checkbox.green {
	--checkbox-color: #ca7b39;
	--checkbox-bg: #f8eadc;
	--checkbox-border: #e5b884;
}

/* Animation */
@keyframes bounce {

	0%,
	100% {
		transform: scale(1);
	}

	50% {
		transform: scale(1.1);
	}
}

.ios-checkbox input:checked+.checkbox-wrapper {
	animation: bounce 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.wp-block-post-title {
	text-align: center;
}

.order-complete-wrapper {
	margin-top: 30px;
	border-top: 1px solid #ccc;
	padding-top: 20px;
}

.order-details {
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.field-wrapper {
	margin-bottom: 10px;
}

.field-wrapper label {
	display: block;
	margin-bottom: 5px;
	font-weight: 500;
}

.field-wrapper input,
.field-wrapper select,
.field-wrapper textarea {
	width: 100%;
	padding: 8px;
	border: 1px solid #222;
	border-radius: 0;
}

/* Order Filters */
.orders-filters {
	margin: 20px 0;
	padding: 15px;
	background-color: #f9f9f9;
	border: 1px solid #222;
}

.filter-controls {
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
	align-items: flex-end;
}

.filter-group {
	display: flex;
	flex-direction: column;
	min-width: 200px;
}

.filter-group label {
	margin-bottom: 5px;
	font-weight: 500;
}

.filter-group select,
.filter-group input {
	padding: 8px;
	border: 1px solid #ddd;
}

/* Partner Groups */
.partner-group {
	margin-bottom: 30px;
	border: 1px solid #ddd;
	overflow: hidden;
}

.partner-name {
	margin: 0;
	padding: 10px 15px;
	background-color: #f0f0f0;
	border-bottom: 1px solid #ddd;
	font-size: 16px;
	font-weight: 600;
	text-transform: capitalize;
}

.loading {
	text-align: center;
	padding: 20px;
	font-style: italic;
	color: #777;
}

/* Responsive Adjustments */
@media (max-width: 768px) {
	.filter-controls {
		flex-direction: column;
		align-items: stretch;
	}
	
	.filter-group {
		min-width: auto;
	}
}

/* Mobile Scroll Button */
.scroll-to-order {
	width: 80%;
	display: none;
	position: fixed;
	bottom: 20px;
	left: 50%;
	background: #b15757;
	color: #fff;
	padding: 12px 20px;
	border: none;
	z-index: 100;
	font-size: 14px;
	box-shadow: 0 2px 10px rgba(177, 87, 87, 0.2);
	translate: -50% 0;
	opacity: 0;
	visibility: hidden;
	text-align: center;
	transition: 0.3s ease-in-out;
	justify-content: center;
	align-items: center;
	gap: 12px;
}

@media (max-width: 768px) {
	.scroll-to-order {
		display: flex;
		opacity: 1;
		visibility: visible;
	}
}

.rs-pin-modal {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.5);
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 9999;
}

.rs-pin-modal-content h2 {
    color: #222;
}

.rs-pin-modal-content {
	background: white;
	padding: 2em;
	text-align: center;
}

.rs-pin-modal input {
	margin: 1em 0;
	padding: 0.5em;
	width: 100%;
	box-sizing: border-box;
}

.rs-pin-modal input:focus {
    outline: none;
}

.rs-pin-modal button {
	width: 100%;
}

#rs-submit-pin {
    background: #fff;
    color: #b15757;
    border: 1px solid #b15757;
    border-radius: 0;
	transition: all 0.3s ease-in-out;
}

#rs-submit-pin:hover {
	border: 1px solid #b15757;
	background: #b15757;
	color: #fff;
}

.rs-pin-error {
	color: red;
	margin-top: 1em;
}

.package-price {
	margin-bottom: 10px;
}

.cutoff-notice {
	background-color: #E63946;
	color: #fff;
	padding: 12px 15px;
	margin-bottom: 20px;
	text-align: center;
	font-size: clamp(1.125rem, 1.125rem +((1vw - 0.2rem)* 0.392), 1.375rem);
	display: none;
	position: sticky;
	top: 20px;
	z-index: 2;
}

.cutoff-notice.active {
	display: block;
}

button[type="submit"][disabled] {
	background-color: #923c3b;
	border-color: #923c3b;
	opacity: 0.7;
	cursor: not-allowed;
}

#breakfast-order-form select {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23b15757' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
	padding-right: 35px;
	cursor: pointer;
}

#breakfast-order-form select::-ms-expand {
	display: none;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

/* Hide spin buttons in Firefox */
input[type="number"] {
	-moz-appearance: textfield;
}

/* Alternative Order Button */
.alternative-order-option {
	margin: 2rem auto;
	text-align: center;
	max-width: 400px;
}

.efood-button {
	display: inline-block;
	background: #ca7b39; /* Changed from e-food orange to our new palette */
	color: white;
	text-decoration: none;
	padding: 15px 25px;
	box-shadow: 0 3px 10px rgba(0,0,0,0.1);
	transition: all 0.3s ease;
	text-align: center;
	font-weight: 500;
}

.efood-button:hover {
	background: #c65642;
	transform: translateY(-2px);
	box-shadow: 0 5px 15px rgba(0,0,0,0.15);
	color: white;
}

.efood-button span {
	display: block;
	font-size: 0.9rem;
	opacity: 0.9;
	margin-bottom: 5px;
}

.efood-button strong {
	font-size: 1.1rem;
	font-weight: 700;
}

/* QR Code with Logo */
.qr-code-container {
	position: fixed;
	bottom: 20px;
	right: 20px;
	z-index: 999;
	width: 100px;
	height: 100px;
	background: white;
	border-radius: 8px;
	box-shadow: 0 3px 15px rgba(0,0,0,0.1);
	padding: 5px;
	cursor: pointer;
	transition: all 0.3s ease;
}

.qr-code-container:hover {
	transform: scale(1.05);
}

.qr-code {
	width: 100%;
	height: 100%;
	background-size: contain;
	position: relative;
}

.qr-code-logo {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 30px;
	height: 30px;
	background: white;
	border-radius: 50%;
	padding: 2px;
	box-shadow: 0 2px 5px rgba(0,0,0,0.1);
	z-index: 2;
}

.qr-code-logo img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	border-radius: 50%;
}

/* Disabled Submit Button */
.submit-order[disabled] {
    background-color: #cccccc !important;
    color: #888888 !important;
    cursor: not-allowed !important;
    opacity: 0.7;
    box-shadow: none !important;
}

.submit-order[disabled]:hover {
    background-color: #cccccc !important;
    color: #888888 !important;
    box-shadow: none !important;
}

/* Outside Hours Form Styling */
.outside-hours .package-card {
    opacity: 0.7;
    pointer-events: none;
}

.outside-hours .order-details input,
.outside-hours .order-details select,
.outside-hours .order-details textarea {
    background-color: #f0f0f0;
    border-color: #ddd;
    color: #888;
    pointer-events: none;
}

.breakfast-page-content .breakfast-page-title {
	text-align: center;
	color: #222;
	margin-block: 2rem;
}

.partner-image,
.breakfast-page-container .custom-logo {
    max-width: 100%!important;
    height: auto;
    margin: 0 auto;
    text-align: center;
    max-width: 800px;
    display: flex;
    max-height: 250px;
    margin-block: 3rem;
}

@media (min-width: 768px) {
	.partner-image,
	.breakfast-page-container.custom-logo {
		max-height: 350px;
	}
}

/* Payment Type Styles */
.payment-type-wrapper {
    margin-top: 20px;
}

.payment-options {
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin-top: 10px;
}

.payment-option {
    display: flex;
    align-items: flex-start;
    padding: 15px;
    border: 2px solid #e5b884;
    cursor: pointer;
    transition: all 0.2s ease;
    background: white;
}

.payment-option:hover {
    border-color: #ca7b39;
    transform: translateY(-2px);
}

.payment-option input[type="radio"] {
    margin-top: 3px;
    margin-right: 15px;
}

.payment-icon {
    font-size: 24px;
    margin-right: 15px;
}

.payment-label {
    font-weight: 600;
    font-size: 16px;
    margin-bottom: 5px;
    display: block;
}

.payment-description {
    color: #666;
    font-size: 14px;
    display: block;
}

.payment-option input[type="radio"]:checked + .payment-icon + .payment-label + .payment-description {
    color: #ca7b39;
}

.payment-option input[type="radio"]:checked + .payment-icon + .payment-label {
    color: #ca7b39;
}

.payment-option input[type="radio"]:checked + .payment-icon {
    color: #ca7b39;
}

.payment-option input[type="radio"]:checked {
    accent-color: #ca7b39;
}


.language-switcher-container {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 9999;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

.language-switcher {
    position: relative;
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
    backdrop-filter: blur(10px); 
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    transition: all 0.3s ease;
}

.language-switcher:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(0, 0, 0, 0.15);
}

.language-current {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    color: #333;
    transition: all 0.2s ease;
}

.language-current:hover {
    background: rgba(0, 0, 0, 0.05);
}

.language-icon {
    margin-right: 8px;
    font-size: 16px;
}

.language-code {
    margin-right: 8px;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.5px;
}

.language-arrow {
    font-size: 10px;
    transition: transform 0.2s ease;
}

.language-switcher:hover .language-arrow {
    transform: rotate(180deg);
}

.language-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: white;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.3s ease;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.language-switcher:hover .language-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.language-dropdown { 
    list-style: none;
    margin: 0;
    padding: 8px 0;
}

.language-dropdown li {
    margin: 0;
}

.language-dropdown a {
    display: flex;
    align-items: center;
    padding: 10px 16px;
    text-decoration: none;
    color: #333;
    font-size: 14px;
    transition: all 0.2s ease;
	text-transform: uppercase;
}

.language-dropdown a:hover {
    background: rgba(0, 0, 0, 0.05);
    color: #007cba;
}

.language-dropdown img {
    width: 20px;
    height: auto;
    margin-right: 10px;
}

/* Mobile responsive */
@media (max-width: 768px) {
    .language-switcher-container {
        top: 15px;
        right: 15px;
    }
    
    .language-current {
        padding: 10px 12px;
        font-size: 13px;
    }
    
    .language-dropdown a {
        padding: 8px 12px;
        font-size: 13px;
    }
}

/* Dark mode support */
@media (prefers-color-scheme: dark) {
    .language-switcher {
        background: rgba(30, 30, 30, 0.95);
        border: 1px solid rgba(255, 255, 255, 0.1);
    }
    
    .language-current {
        color: #fff;
    }
    
    .language-current:hover {
        background: rgba(255, 255, 255, 0.1);
    }
    
    .language-dropdown {
        background: #2a2a2a;
        border-top: 1px solid rgba(255, 255, 255, 0.1);
    }
    
    .language-dropdown a {
        color: #fff;
    }
    
    .language-dropdown a:hover {
        background: rgba(255, 255, 255, 0.1);
        color: #4a9eff;
    }
}