/**
 * Group Food Order Taker - Frontend Styles
 * High specificity to prevent theme override
 * @package Group_Food_Order_Taker
 */

/* ============================================
   WRAPPER & FORM CONTAINER
   ============================================ */

.gfot-order-form-wrapper {
	width: 100% !important;
	max-width: 100% !important;
	margin: 30px auto !important;
	padding: 0 20px !important;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif !important;
	line-height: 1.6 !important;
}

.gfot-order-form-wrapper * {
	box-sizing: border-box !important;
}

.gfot-order-form {
	background: #ffffff !important;
	border: none !important;
	border-radius: 12px !important;
	padding: 40px !important;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08), 0 1px 3px rgba(0, 0, 0, 0.05) !important;
	margin: 0 !important;
}

/* ============================================
   SECTIONS
   ============================================ */

.gfot-order-form .gfot-section {
	margin-bottom: 40px !important;
	padding-bottom: 35px !important;
	border-bottom: 2px solid #f0f0f1 !important;
	position: relative !important;
}

.gfot-order-form .gfot-section:last-child {
	border-bottom: none !important;
	margin-bottom: 0 !important;
	padding-bottom: 0 !important;
}

.gfot-order-form .gfot-section h3 {
	margin: 0 0 25px 0 !important;
	font-size: 24px !important;
	font-weight: 700 !important;
	color: #1d2327 !important;
	line-height: 1.3 !important;
	letter-spacing: -0.02em !important;
}

/* Menu Display Section - Centered Heading */
.gfot-order-form .gfot-menu-display h3 {
	text-align: center !important;
}

/* Menu Items Display - Beautiful Styling */
.gfot-order-form .gfot-menu-items {
	margin-top: 35px !important;
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 25px !important;
	align-items: start !important;
}

@media (max-width: 1024px) {
	.gfot-order-form .gfot-menu-items {
		grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
	}
}

.gfot-order-form .gfot-menu-category {
	margin-bottom: 0 !important;
	padding: 20px 18px !important;
	background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%) !important;
	border: 2px solid #e5e7eb !important;
	border-radius: 12px !important;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06) !important;
	transition: all 0.3s ease !important;
	width: 100% !important;
	box-sizing: border-box !important;
}

.gfot-order-form .gfot-menu-category:hover {
	transform: translateY(-3px) !important;
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1) !important;
	border-color: #2271b1 !important;
}

.gfot-order-form .gfot-menu-category h4 {
	color: #2271b1 !important;
	font-size: 18px !important;
	font-weight: 700 !important;
	margin-bottom: 12px !important;
	text-align: center !important;
	letter-spacing: 1px !important;
	text-transform: uppercase !important;
	position: relative !important;
	padding-bottom: 10px !important;
}

.gfot-order-form .gfot-menu-category h4::after {
	content: '' !important;
	position: absolute !important;
	bottom: 0 !important;
	left: 50% !important;
	transform: translateX(-50%) !important;
	width: 60px !important;
	height: 3px !important;
	background: linear-gradient(90deg, #2271b1 0%, #135e96 100%) !important;
	border-radius: 2px !important;
}

.gfot-order-form .gfot-menu-category ul {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	text-align: left !important;
}

.gfot-order-form .gfot-menu-category li {
	padding: 8px 0 !important;
	color: #1d2327 !important;
	font-size: 13px !important;
	line-height: 1.5 !important;
	font-weight: 400 !important;
	border-bottom: 1px solid #f0f0f1 !important;
	transition: all 0.2s ease !important;
	display: flex !important;
	align-items: flex-start !important;
	gap: 8px !important;
}

.gfot-order-form .gfot-menu-category li svg {
	flex-shrink: 0 !important;
	margin-top: 2px !important;
	color: #2271b1 !important;
	width: 16px !important;
	height: 16px !important;
}

.gfot-order-form .gfot-menu-category li:last-child {
	border-bottom: none !important;
}

.gfot-order-form .gfot-menu-category li:hover {
	color: #2271b1 !important;
}

.gfot-order-form .gfot-menu-category p {
	text-align: center !important;
	font-size: 13px !important;
	color: #646970 !important;
	margin-top: 12px !important;
	font-style: italic !important;
	padding-top: 12px !important;
	border-top: 1px solid #e5e7eb !important;
}

/* ============================================
   SECTION HEADER
   ============================================ */

.gfot-order-form .gfot-section-header {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	margin-bottom: 25px !important;
	flex-wrap: wrap !important;
	gap: 15px !important;
}

.gfot-order-form .gfot-section-header h3 {
	margin-bottom: 0 !important;
}

/* ============================================
   FORM FIELDS
   ============================================ */

.gfot-order-form .gfot-field {
	margin-bottom: 24px !important;
	position: relative !important;
	transition: all 0.3s ease !important;
}

.gfot-order-form .gfot-field:focus-within {
	transform: translateY(-2px) !important;
}

.gfot-order-form .gfot-field:last-child {
	margin-bottom: 0 !important;
}

.gfot-order-form .gfot-field label {
	display: block !important;
	margin-bottom: 10px !important;
	font-weight: 600 !important;
	font-size: 14px !important;
	color: #1d2327 !important;
	line-height: 1.5 !important;
	transition: color 0.2s ease !important;
}

.gfot-order-form .gfot-field:focus-within label {
	color: #2271b1 !important;
}

.gfot-order-form .gfot-field .required {
	color: #d63638 !important;
	margin-left: 4px !important;
	font-weight: 700 !important;
}

/* Input Fields */
.gfot-order-form .gfot-field input[type="text"],
.gfot-order-form .gfot-field input[type="email"],
.gfot-order-form .gfot-field input[type="tel"],
.gfot-order-form .gfot-field textarea {
	width: 100% !important;
	padding: 13px 18px !important;
	border: 2px solid #dcdcde !important;
	border-radius: 10px !important;
	font-size: 15px !important;
	font-family: inherit !important;
	line-height: 1.6 !important;
	color: #1d2327 !important;
	background-color: #ffffff !important;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	appearance: none !important;
	min-height: 48px !important;
	box-sizing: border-box !important;
}

.gfot-order-form .gfot-field input[type="text"]:focus,
.gfot-order-form .gfot-field input[type="email"]:focus,
.gfot-order-form .gfot-field input[type="tel"]:focus,
.gfot-order-form .gfot-field textarea:focus {
	outline: none !important;
	border-color: #2271b1 !important;
	box-shadow: 0 0 0 4px rgba(34, 113, 177, 0.12), 0 2px 8px rgba(34, 113, 177, 0.15) !important;
	background-color: #ffffff !important;
	transform: translateY(-1px) !important;
}

.gfot-order-form .gfot-field input[type="text"]:hover:not(:focus),
.gfot-order-form .gfot-field input[type="email"]:hover:not(:focus),
.gfot-order-form .gfot-field input[type="tel"]:hover:not(:focus),
.gfot-order-form .gfot-field textarea:hover:not(:focus) {
	border-color: #8c8f94 !important;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05) !important;
}

.gfot-order-form .gfot-field input::placeholder,
.gfot-order-form .gfot-field textarea::placeholder {
	color: #8c8f94 !important;
	opacity: 1 !important;
	font-size: 14px !important;
}

/* Select Dropdown Styling - Enhanced */
.gfot-order-form .gfot-field select {
	width: 100% !important;
	padding: 0px 50px 0px 18px !important;
	border: 2px solid #dcdcde !important;
	border-radius: 10px !important;
	font-size: 15px !important;
	font-family: inherit !important;
	line-height: 1.6 !important;
	color: #1d2327 !important;
	background-color: #ffffff !important;
	background-image: url("data:image/svg+xml,%3Csvg width='14' height='9' viewBox='0 0 14 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L7 7.5L13 1.5' stroke='%231d2327' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
	background-repeat: no-repeat !important;
	background-position: right 18px center !important;
	background-size: 14px 9px !important;
	cursor: pointer !important;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	appearance: none !important;
	min-height: 48px !important;
	box-sizing: border-box !important;
}

.gfot-order-form .gfot-field select:focus {
	outline: none !important;
	border-color: #2271b1 !important;
	box-shadow: 0 0 0 4px rgba(34, 113, 177, 0.12), 0 2px 8px rgba(34, 113, 177, 0.15) !important;
	background-color: #ffffff !important;
	transform: translateY(-1px) !important;
	background-image: url("data:image/svg+xml,%3Csvg width='14' height='9' viewBox='0 0 14 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L7 7.5L13 1.5' stroke='%232271b1' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
}

.gfot-order-form .gfot-field select:hover:not(:focus) {
	border-color: #8c8f94 !important;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05) !important;
	background-color: #fafafa !important;
}

.gfot-order-form .gfot-field select:active {
	transform: translateY(0) !important;
}

.gfot-order-form .gfot-field select option {
	padding: 14px 18px !important;
	background-color: #ffffff !important;
	color: #1d2327 !important;
	font-size: 15px !important;
	line-height: 1.6 !important;
	min-height: 44px !important;
}

.gfot-order-form .gfot-field select option:hover,
.gfot-order-form .gfot-field select option:focus,
.gfot-order-form .gfot-field select option:checked {
	background-color: #f0f6fc !important;
	color: #2271b1 !important;
	font-weight: 500 !important;
}

.gfot-order-form .gfot-field select option:disabled {
	color: #8c8f94 !important;
	background-color: #f6f7f7 !important;
}

/* Textarea */
.gfot-order-form .gfot-field textarea {
	resize: vertical !important;
	min-height: 110px !important;
	font-family: inherit !important;
	padding: 13px 18px !important;
}

.gfot-order-form .gfot-field textarea:focus {
	transform: translateY(-1px) !important;
}

.gfot-order-form .gfot-field textarea:hover:not(:focus) {
	border-color: #8c8f94 !important;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05) !important;
}

/* Course Description Box - Full Width & Beautiful */
.gfot-order-form .gfot-guest-item .gfot-course-description {
	margin-top: 20px !important;
	width: 100% !important;
	grid-column: 1 / -1 !important;
	padding: 0 !important;
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	animation: gfot-fade-in 0.3s ease-out !important;
}

.gfot-order-form .gfot-course-desc-header {
	background: linear-gradient(135deg, #2271b1 0%, #135e96 100%) !important;
	padding: 14px 20px !important;
	border-radius: 12px 12px 0 0 !important;
	text-align: center !important;
	box-shadow: 0 4px 12px rgba(34, 113, 177, 0.2) !important;
}

.gfot-order-form .gfot-course-desc-header h4 {
	margin: 0 !important;
	color: #ffffff !important;
	font-size: 18px !important;
	font-weight: 700 !important;
	letter-spacing: 0.5px !important;
}

.gfot-order-form .gfot-course-desc-content {
	background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%) !important;
	padding: 16px 20px !important;
	border: 2px solid #e5e7eb !important;
	border-top: none !important;
	border-radius: 0 0 12px 12px !important;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08) !important;
	display: grid !important;
	gap: 15px !important;
}

/* 2 Course Package - 2 columns, always 2 boxes in one row */
.gfot-course-2-desc .gfot-course-desc-content {
	grid-template-columns: repeat(2, 1fr) !important;
	grid-template-rows: auto !important;
	display: grid !important;
}

/* Hide both 2-course content divs by default - only show when combo is selected via JavaScript */
.gfot-course-2-desc .gfot-course-2-starter-main:not(.gfot-show) {
	display: none !important;
}

.gfot-course-2-desc .gfot-course-2-main-dessert:not(.gfot-show) {
	display: none !important;
}

/* Show when class is added */
.gfot-course-2-desc .gfot-course-2-starter-main.gfot-show {
	display: grid !important;
}

.gfot-course-2-desc .gfot-course-2-main-dessert.gfot-show {
	display: grid !important;
}

/* Ensure 2-course boxes stay in one row - force both boxes to row 1 */
.gfot-course-2-desc .gfot-course-desc-content .gfot-course-category {
	grid-row: 1 !important;
	grid-column: auto !important;
}

/* Make sure dessert box in 2-course doesn't span full width */
.gfot-course-2-desc .gfot-course-desc-content .gfot-course-category-dessert {
	grid-column: auto !important;
	width: auto !important;
	max-width: none !important;
	justify-self: auto !important;
}

/* 3 Course Package - 2 columns, dessert in second row center */
.gfot-course-3-desc .gfot-course-desc-content {
	grid-template-columns: repeat(2, 1fr) !important;
	grid-template-rows: auto auto !important;
	gap: 15px !important;
}

.gfot-order-form .gfot-course-3-desc .gfot-course-category:first-child,
.gfot-order-form .gfot-course-3-desc .gfot-course-category:nth-child(2) {
	grid-row: 1 !important;
}

/* Dessert box styling - only for 3-course */
.gfot-course-3-desc .gfot-course-category-dessert {
	grid-column: 1 / -1 !important;
	grid-row: 2 !important;
	justify-self: center !important;
	width: calc(50% - 7.5px) !important;
	max-width: calc(50% - 7.5px) !important;
}

/* 2-course dessert box should be normal */
.gfot-course-2-desc .gfot-course-category-dessert {
	grid-column: auto !important;
	grid-row: 1 !important;
	justify-self: auto !important;
	width: auto !important;
	max-width: none !important;
}

@media (max-width: 1024px) {
	.gfot-order-form .gfot-course-desc-content {
		grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)) !important;
	}

	.gfot-course-2-desc .gfot-course-desc-content,
	.gfot-course-3-desc .gfot-course-desc-content {
		grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)) !important;
	}

	.gfot-order-form .gfot-course-category-dessert {
		grid-column: auto !important;
		justify-self: auto !important;
	}
}

.gfot-order-form .gfot-course-category {
	padding: 14px 16px !important;
	background: #ffffff !important;
	border: 2px solid #e5e7eb !important;
	border-radius: 8px !important;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05) !important;
	transition: all 0.2s ease !important;
}

.gfot-order-form .gfot-course-category:hover {
	border-color: #2271b1 !important;
	box-shadow: 0 4px 12px rgba(34, 113, 177, 0.15) !important;
	transform: translateY(-2px) !important;
}

.gfot-order-form .gfot-course-category h5 {
	color: #2271b1 !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	margin: 0 0 10px 0 !important;
	padding-bottom: 8px !important;
	border-bottom: 2px solid #e5e7eb !important;
	text-transform: uppercase !important;
	letter-spacing: 0.5px !important;
}

.gfot-order-form .gfot-course-category ul {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

.gfot-order-form .gfot-course-category li {
	padding: 6px 0 !important;
	color: #1d2327 !important;
	font-size: 12px !important;
	line-height: 1.4 !important;
	font-weight: 400 !important;
	border-bottom: 1px solid #f0f0f1 !important;
	transition: all 0.2s ease !important;
	display: flex !important;
	align-items: flex-start !important;
	gap: 6px !important;
}

.gfot-order-form .gfot-course-category li:last-child {
	border-bottom: none !important;
	padding-bottom: 0 !important;
}

.gfot-order-form .gfot-course-category li .gfot-check-icon {
	flex-shrink: 0 !important;
	margin-top: 1px !important;
	color: #2271b1 !important;
	width: 14px !important;
	height: 14px !important;
}

.gfot-order-form .gfot-course-category li:last-child {
	border-bottom: none !important;
}

.gfot-order-form .gfot-course-category li:hover {
	color: #2271b1 !important;
}

.gfot-order-form .gfot-course-note {
	margin: 10px 0 0 0 !important;
	padding: 8px 12px !important;
	background: #f0f6fc !important;
	border-left: 3px solid #2271b1 !important;
	border-radius: 6px !important;
	color: #646970 !important;
	font-size: 11px !important;
	font-style: italic !important;
	line-height: 1.4 !important;
}

/* ============================================
   GUEST ITEMS
   ============================================ */

.gfot-order-form .gfot-guests-container {
	margin-top: 25px !important;
}

.gfot-order-form .gfot-guest-item {
	background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%) !important;
	border: 2px solid #e5e5e5 !important;
	border-radius: 12px !important;
	padding: 25px !important;
	margin-bottom: 20px !important;
	position: relative !important;
	transition: all 0.3s ease !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04) !important;
}

.gfot-order-form .gfot-guest-item:hover {
	border-color: #2271b1 !important;
	box-shadow: 0 4px 12px rgba(34, 113, 177, 0.1) !important;
	transform: translateY(-2px) !important;
}

.gfot-order-form .gfot-guest-header {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	margin-bottom: 20px !important;
	padding-bottom: 18px !important;
	border-bottom: 2px solid #e5e5e5 !important;
}

.gfot-order-form .gfot-guest-header h4 {
	margin: 0 !important;
	font-size: 18px !important;
	font-weight: 700 !important;
	color: #1d2327 !important;
	line-height: 1.4 !important;
	display: flex !important;
	align-items: center !important;
}

/* Toggle Guest Collapse/Expand Button */
.gfot-order-form .gfot-toggle-guest {
	background: transparent !important;
	border: none !important;
	padding: 4px 8px !important;
	margin: 0 4px 0 0 !important;
	cursor: pointer !important;
	color: #646970 !important;
	transition: all 0.2s ease !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	line-height: 1 !important;
}

.gfot-order-form .gfot-toggle-guest:hover {
	color: #2271b1 !important;
	background: #f0f6fc !important;
	border-radius: 4px !important;
}

.gfot-order-form .gfot-toggle-guest .gfot-toggle-icon {
	transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
	color: #646970 !important;
	transform: rotate(0deg) !important;
}

.gfot-order-form .gfot-toggle-guest:hover .gfot-toggle-icon {
	color: #2271b1 !important;
}

.gfot-order-form .gfot-guest-number {
	font-weight: 500 !important;
	color: #646970 !important;
	font-size: 16px !important;
}

.gfot-order-form .gfot-remove-guest {
	color: #d63638 !important;
	text-decoration: none !important;
	cursor: pointer !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	padding: 6px 12px !important;
	border-radius: 6px !important;
	background: transparent !important;
	border: 1px solid transparent !important;
	transition: all 0.2s ease !important;
}

.gfot-order-form .gfot-remove-guest:hover {
	color: #b32d2e !important;
	background: rgba(214, 54, 56, 0.1) !important;
	border-color: #d63638 !important;
	text-decoration: none !important;
}

.gfot-order-form .gfot-guest-fields {
	display: grid !important;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)) !important;
	gap: 20px !important;
	overflow: hidden !important;
	max-height: 10000px !important;
	opacity: 1 !important;
	transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease !important;
}

/* Collapsed state */
.gfot-order-form .gfot-guest-item.gfot-guest-collapsed .gfot-guest-fields {
	max-height: 0 !important;
	opacity: 0 !important;
	overflow: hidden !important;
}

.gfot-order-form .gfot-guest-fields .gfot-field {
	margin-bottom: 0 !important;
}

/* Food Selection Radio Buttons */
.gfot-order-form .gfot-food-selection {
	margin-top: 25px !important;
	padding-top: 25px !important;
	border-top: 2px solid #e5e7eb !important;
	grid-column: 1 / -1 !important; /* Span full width across all columns */
	width: 100% !important;
}

.gfot-order-form .gfot-radio-group {
	display: flex !important;
	flex-direction: column !important;
	gap: 12px !important;
	margin-top: 12px !important;
}

.gfot-order-form .gfot-radio-label {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	padding: 14px 16px !important;
	background: #ffffff !important;
	border: 2px solid #e5e7eb !important;
	border-radius: 10px !important;
	cursor: pointer !important;
	transition: all 0.3s ease !important;
	position: relative !important;
}

.gfot-order-form .gfot-radio-label:hover {
	border-color: #2271b1 !important;
	background: #f0f7ff !important;
	transform: translateX(4px) !important;
	box-shadow: 0 2px 8px rgba(34, 113, 177, 0.1) !important;
}

.gfot-order-form .gfot-radio-label input[type="radio"] {
	width: 20px !important;
	height: 20px !important;
	margin: 0 !important;
	flex-shrink: 0 !important;
	cursor: pointer !important;
	accent-color: #2271b1 !important;
	align-self: center !important;
}

.gfot-order-form .gfot-radio-label input[type="radio"]:checked + .gfot-radio-text {
	color: #2271b1 !important;
	font-weight: 600 !important;
}

.gfot-order-form .gfot-radio-label:has(input[type="radio"]:checked) {
	border-color: #2271b1 !important;
	background: linear-gradient(135deg, #f0f7ff 0%, #e6f2ff 100%) !important;
	box-shadow: 0 2px 12px rgba(34, 113, 177, 0.15) !important;
}

.gfot-order-form .gfot-radio-text {
	flex: 1 !important;
	color: #1d2327 !important;
	font-size: 14px !important;
	line-height: 1.5 !important;
	transition: all 0.2s ease !important;
}

.gfot-order-form .gfot-food-selection .gfot-field {
	margin-bottom: 28px !important;
}

.gfot-order-form .gfot-food-selection .gfot-field:last-child {
	margin-bottom: 0 !important;
}

.gfot-order-form .gfot-food-selection label {
	font-weight: 600 !important;
	color: #1d2327 !important;
	font-size: 15px !important;
	margin-bottom: 0 !important;
}

/* ============================================
   BUTTONS
   ============================================ */

.gfot-order-form .gfot-add-guest,
.gfot-order-form .gfot-add-guest.button {
	padding: 12px 24px !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	border-radius: 8px !important;
	cursor: pointer !important;
	transition: all 0.2s ease !important;
	background: #2271b1 !important;
	color: #ffffff !important;
	border: 2px solid #2271b1 !important;
	text-decoration: none !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 8px !important;
	line-height: 1.5 !important;
}

.gfot-order-form .gfot-add-guest:hover,
.gfot-order-form .gfot-add-guest.button:hover {
	background: #135e96 !important;
	border-color: #135e96 !important;
	color: #ffffff !important;
	transform: translateY(-1px) !important;
	box-shadow: 0 4px 12px rgba(34, 113, 177, 0.3) !important;
}

.gfot-order-form .gfot-add-guest:active,
.gfot-order-form .gfot-add-guest.button:active {
	transform: translateY(0) !important;
}

.gfot-order-form .gfot-submit-button,
.gfot-order-form .gfot-submit-button.button,
.gfot-order-form .gfot-submit-button.button-primary {
	padding: 18px 48px !important;
	font-size: 18px !important;
	font-weight: 700 !important;
	border-radius: 10px !important;
	cursor: pointer !important;
	transition: all 0.3s ease !important;
	background: linear-gradient(135deg, #2271b1 0%, #135e96 100%) !important;
	color: #ffffff !important;
	border: none !important;
	text-decoration: none !important;
	display: inline-block !important;
	box-shadow: 0 4px 15px rgba(34, 113, 177, 0.3) !important;
	text-transform: none !important;
	letter-spacing: 0.01em !important;
}

.gfot-order-form .gfot-submit-button:hover:not(:disabled),
.gfot-order-form .gfot-submit-button.button:hover:not(:disabled),
.gfot-order-form .gfot-submit-button.button-primary:hover:not(:disabled) {
	background: linear-gradient(135deg, #135e96 0%, #0f4c75 100%) !important;
	transform: translateY(-2px) !important;
	box-shadow: 0 6px 20px rgba(34, 113, 177, 0.4) !important;
	color: #ffffff !important;
}

.gfot-order-form .gfot-submit-button:active:not(:disabled),
.gfot-order-form .gfot-submit-button.button:active:not(:disabled),
.gfot-order-form .gfot-submit-button.button-primary:active:not(:disabled) {
	transform: translateY(0) !important;
}

.gfot-order-form .gfot-submit-button:disabled,
.gfot-order-form .gfot-submit-button.button:disabled,
.gfot-order-form .gfot-submit-button.button-primary:disabled {
	opacity: 0.6 !important;
	cursor: not-allowed !important;
	transform: none !important;
	box-shadow: none !important;
}

/* ============================================
   PRICE SUMMARY
   ============================================ */

.gfot-order-form .gfot-price-summary {
	background: linear-gradient(135deg, #f6f7f7 0%, #ffffff 100%) !important;
	padding: 30px !important;
	border-radius: 12px !important;
	border: 2px solid #e5e5e5 !important;
}

.gfot-order-form .gfot-price-breakdown {
	display: flex !important;
	flex-direction: column !important;
	gap: 16px !important;
}

.gfot-order-form .gfot-price-row {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	padding: 12px 0 !important;
}

.gfot-order-form .gfot-price-row:not(:last-child) {
	border-bottom: 1px solid #dcdcde !important;
}

.gfot-order-form .gfot-price-label {
	font-weight: 600 !important;
	font-size: 15px !important;
	color: #1d2327 !important;
}

.gfot-order-form .gfot-price-value {
	color: #646970 !important;
	margin-left: auto !important;
	margin-right: 20px !important;
	font-size: 15px !important;
	font-weight: 500 !important;
}

.gfot-order-form .gfot-price-amount {
	font-weight: 700 !important;
	color: #1d2327 !important;
	font-size: 16px !important;
}

.gfot-order-form .gfot-total-row {
	border-top: 3px solid #2271b1 !important;
	padding-top: 20px !important;
	margin-top: 8px !important;
}

.gfot-order-form .gfot-total-row .gfot-price-label {
	font-size: 18px !important;
	font-weight: 700 !important;
}

.gfot-order-form .gfot-total-row .gfot-price-amount {
	font-size: 24px !important;
	color: #2271b1 !important;
	font-weight: 800 !important;
}

/* ============================================
   SUBMIT SECTION
   ============================================ */

.gfot-order-form .gfot-submit-section {
	text-align: center !important;
	padding-top: 20px !important;
}

/* ============================================
   MESSAGES
   ============================================ */

.gfot-order-form .gfot-messages {
	margin-top: 20px !important;
}

.gfot-order-form .gfot-error {
	background: linear-gradient(135deg, #fcf0f1 0%, #fff5f5 100%) !important;
	border: 2px solid #d63638 !important;
	color: #8a2424 !important;
	padding: 16px 20px !important;
	border-radius: 8px !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	display: flex !important;
	align-items: center !important;
	gap: 10px !important;
}

.gfot-order-form .gfot-success {
	background: linear-gradient(135deg, #f0f6fc 0%, #e8f4f8 100%) !important;
	border: 2px solid #2271b1 !important;
	color: #0a4b78 !important;
	padding: 16px 20px !important;
	border-radius: 8px !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	display: flex !important;
	align-items: center !important;
	gap: 10px !important;
}

/* ============================================
   RESPONSIVE DESIGN
   ============================================ */

@media (max-width: 768px) {
	.gfot-order-form-wrapper {
		padding: 0 15px !important;
		margin: 20px auto !important;
	}

	.gfot-order-form {
		padding: 25px 20px !important;
		border-radius: 10px !important;
	}

	.gfot-order-form .gfot-section {
		margin-bottom: 30px !important;
		padding-bottom: 25px !important;
	}

	.gfot-order-form .gfot-section h3 {
		font-size: 20px !important;
		margin-bottom: 20px !important;
	}

	.gfot-order-form .gfot-section-header {
		flex-direction: column !important;
		align-items: stretch !important;
		gap: 15px !important;
	}

	.gfot-order-form .gfot-section-header h3 {
		margin-bottom: 0 !important;
	}

	.gfot-order-form .gfot-add-guest,
	.gfot-order-form .gfot-add-guest.button {
		width: 100% !important;
		justify-content: center !important;
	}

	.gfot-order-form .gfot-guest-fields {
		grid-template-columns: 1fr !important;
		gap: 18px !important;
	}

	.gfot-order-form .gfot-food-selection {
		grid-column: 1 / -1 !important;
		width: 100% !important;
	}

	.gfot-order-form .gfot-course-desc-content {
		grid-template-columns: 1fr !important;
		gap: 15px !important;
		padding: 14px 16px !important;
	}

	.gfot-order-form .gfot-course-3-desc .gfot-course-desc-content {
		grid-template-columns: 1fr !important;
		grid-template-rows: auto !important;
	}

	.gfot-order-form .gfot-course-category-dessert {
		grid-column: 1 !important;
		grid-row: auto !important;
		max-width: 100% !important;
	}

	.gfot-order-form .gfot-course-desc-header {
		padding: 12px 16px !important;
	}

	.gfot-order-form .gfot-course-desc-header h4 {
		font-size: 16px !important;
	}

	.gfot-order-form .gfot-course-category h5 {
		font-size: 13px !important;
		margin-bottom: 6px !important;
		padding-bottom: 6px !important;
	}

	.gfot-order-form .gfot-course-category li {
		font-size: 12px !important;
		padding: 4px 0 !important;
	}

	.gfot-order-form .gfot-menu-items {
		grid-template-columns: 1fr !important;
	}

	.gfot-order-form .gfot-guest-item {
		padding: 20px !important;
	}

	.gfot-order-form .gfot-price-summary {
		padding: 20px !important;
	}

	.gfot-order-form .gfot-price-row {
		flex-wrap: wrap !important;
		gap: 8px !important;
	}

	.gfot-order-form .gfot-price-value {
		margin-left: 0 !important;
		margin-right: 0 !important;
		width: 100% !important;
		margin-top: 4px !important;
	}

	.gfot-order-form .gfot-submit-button,
	.gfot-order-form .gfot-submit-button.button,
	.gfot-order-form .gfot-submit-button.button-primary {
		width: 100% !important;
		padding: 16px 32px !important;
		font-size: 16px !important;
	}
}

@media (max-width: 480px) {
	.gfot-order-form {
		padding: 20px 15px !important;
	}

	.gfot-order-form .gfot-section h3 {
		font-size: 18px !important;
	}

	.gfot-order-form .gfot-field input[type="text"],
	.gfot-order-form .gfot-field input[type="email"],
	.gfot-order-form .gfot-field input[type="tel"],
	.gfot-order-form .gfot-field textarea {
		padding: 13px 16px !important;
		font-size: 14px !important;
		min-height: 48px !important;
	}

	.gfot-order-form .gfot-field select {
		padding: 0px 45px 0px 16px !important;
		font-size: 14px !important;
		min-height: 48px !important;
		background-position: right 16px center !important;
	}
}

/* ============================================
   ANIMATIONS
   ============================================ */

@keyframes gfot-fade-in {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.gfot-order-form .gfot-guest-item {
	animation: gfot-fade-in 0.3s ease-out !important;
}

/* ============================================
   ISOLATION - Prevent Theme Override
   ============================================ */

.gfot-order-form-wrapper {
	isolation: isolate !important;
}

.gfot-order-form {
	isolation: isolate !important;
}

/* Reset any theme styles that might interfere */
.gfot-order-form-wrapper *,
.gfot-order-form-wrapper *::before,
.gfot-order-form-wrapper *::after {
	box-sizing: border-box !important;
}

/* Ensure form elements don't inherit theme styles */
.gfot-order-form input,
.gfot-order-form select,
.gfot-order-form textarea,
.gfot-order-form button {
	font-family: inherit !important;
	line-height: inherit !important;
}
