/**
 * ID Restaurant Menu — Frontend Styles
 *
 * All display style templates.
 *
 * @package ID_Restaurant_Menu
 * @since   1.0.0
 */

/* ==========================================================================
   Shared / Base Styles
   ========================================================================== */

.idrm-menu {
	max-width: 900px;
	margin: 0 auto;
	padding: 20px 0;
	line-height: 1.5;
}

.idrm-menu *,
.idrm-menu *::before,
.idrm-menu *::after {
	box-sizing: border-box;
}

/* Reset theme defaults — prevent themes from inflating menu items */
.idrm-menu h2,
.idrm-menu h3,
.idrm-menu p {
	margin: 0;
	padding: 0;
}

.idrm-category {
	margin-bottom: 40px;
}

.idrm-category:last-child {
	margin-bottom: 0;
}

.idrm-menu .idrm-category-title {
	margin: 0 0 20px;
	padding: 0;
}

/* Menu & category descriptions */
.idrm-menu-description {
	text-align: center;
	margin-bottom: 24px;
	opacity: 0.8;
	font-size: 0.95em;
}

.idrm-menu .idrm-category-description {
	margin: -12px 0 20px;
	opacity: 0.7;
	font-size: 0.9em;
}

.idrm-item {
	margin-bottom: 16px;
	overflow: hidden;
}

.idrm-item:last-child {
	margin-bottom: 0;
}

.idrm-menu .idrm-item-header {
	display: flex;
	align-items: baseline;
	gap: 8px;
	line-height: 1.3;
}

.idrm-menu .idrm-item-name {
	font-weight: 600;
}

.idrm-menu .idrm-item-price {
	font-weight: 600;
	white-space: nowrap;
}

/* Price variants (size-based pricing) */
.idrm-price-variants {
	display: inline-flex;
	align-items: baseline;
	gap: 4px;
	flex-wrap: wrap;
}

.idrm-variant-label {
	opacity: 0.7;
	font-weight: 400;
	font-size: 0.85em;
}

.idrm-variant-sep {
	opacity: 0.4;
	margin: 0 2px;
}

.idrm-menu .idrm-item-description {
	margin: 4px 0 0;
	opacity: 0.8;
	font-size: 0.9em;
}

.idrm-no-items {
	text-align: center;
	padding: 40px 20px;
	opacity: 0.6;
}

/* Dietary flags */
.idrm-dietary-flags {
	display: inline-flex;
	gap: 4px;
	margin-top: 4px;
}

.idrm-flag {
	display: inline-block;
	padding: 1px 6px;
	border-radius: 3px;
	font-size: 0.7em;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	line-height: 1.6;
}

.idrm-flag-gf { background: #e8f5e9; color: #2e7d32; }
.idrm-flag-v  { background: #e8f5e9; color: #1b5e20; }
.idrm-flag-vg { background: #c8e6c9; color: #1b5e20; }
.idrm-flag-df { background: #e3f2fd; color: #1565c0; }
.idrm-flag-n  { background: #fff3e0; color: #e65100; }

/* Featured badge */
.idrm-featured-badge {
	display: inline-block;
	padding: 1px 8px;
	border-radius: 3px;
	font-size: 0.7em;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	background: #fff8e1;
	color: var(--idrm-primary, #f9a825);
	margin-left: 8px;
	vertical-align: middle;
}

/* Featured styles */
.idrm-featured-border {
	border-left: 3px solid var(--idrm-primary, #f9a825);
	padding-left: 12px;
}

.idrm-featured-background {
	background: #fffde7;
	padding: 12px;
	border-radius: 6px;
}

/* PDF button */
.idrm-pdf-download {
	text-align: center;
	margin-bottom: 24px;
}

.idrm-pdf-download a.idrm-pdf-btn,
.idrm-pdf-download a.idrm-pdf-btn:link,
.idrm-pdf-download a.idrm-pdf-btn:visited {
	display: inline-block;
	padding: 10px 24px;
	background: var(--idrm-button-bg, #333) !important;
	color: var(--idrm-button-text, #fff) !important;
	text-decoration: none !important;
	border: none;
	border-radius: 4px;
	font-size: 0.9em;
	line-height: 1.2;
	transition: background 0.2s, filter 0.2s;
}

.idrm-pdf-download a.idrm-pdf-btn:hover,
.idrm-pdf-download a.idrm-pdf-btn:focus,
.idrm-pdf-download a.idrm-pdf-btn:active {
	background: var(--idrm-button-bg, #333) !important;
	color: var(--idrm-button-text, #fff) !important;
	text-decoration: none !important;
	filter: brightness(1.15);
}

/* ==========================================================================
   1. Elegant Style
   ========================================================================== */

.idrm-style-elegant {
	font-family: Georgia, "Times New Roman", serif;
}

.idrm-style-elegant .idrm-category-title {
	font-size: 1.6em;
	text-align: center;
	text-transform: uppercase;
	letter-spacing: 3px;
	font-weight: 400;
}

.idrm-elegant-divider {
	width: 60px;
	height: 1px;
	background: var(--idrm-primary, #c9a96e);
	margin: 12px auto 24px;
}

.idrm-style-elegant .idrm-category-title {
	color: var(--idrm-text, inherit);
}

.idrm-style-elegant .idrm-category-description {
	text-align: center;
	font-style: italic;
	color: var(--idrm-text-muted, #666);
	margin: -16px 0 24px;
}

.idrm-style-elegant .idrm-item-header {
	display: flex;
	align-items: baseline;
}

.idrm-style-elegant .idrm-item-name {
	font-weight: 600;
	font-size: 1.05em;
	color: var(--idrm-text, inherit);
}

.idrm-style-elegant .idrm-item-dots {
	flex: 1;
	border-bottom: 1px dotted #ccc;
	margin: 0 8px;
	min-width: 20px;
	align-self: center;
	height: 0;
}

.idrm-style-elegant .idrm-item-price {
	font-weight: 600;
	font-size: 1.05em;
	color: var(--idrm-primary, #c9a96e);
}

.idrm-style-elegant .idrm-item-description {
	font-style: italic;
	color: var(--idrm-text-muted, #666);
	font-size: 0.88em;
}

.idrm-style-elegant .idrm-item-image {
	float: right;
	margin: 0 0 12px 16px;
	width: 120px;
}

.idrm-style-elegant .idrm-item-image img {
	width: 100%;
	height: auto;
	border-radius: 4px;
}

.idrm-style-elegant .idrm-featured-badge {
	background: var(--idrm-primary, #c9a96e);
	color: var(--idrm-primary-contrast, #fff);
}

.idrm-style-elegant .idrm-featured-border {
	border-left-color: var(--idrm-primary, #c9a96e);
}

.idrm-style-elegant .idrm-featured-background {
	background: rgba(201, 169, 110, 0.08);
}

/* ==========================================================================
   2. Modern Style
   ========================================================================== */

.idrm-style-modern {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.idrm-style-modern .idrm-category {
	background: #fff;
	border-radius: 8px;
	padding: 24px;
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
}

.idrm-style-modern .idrm-category-title {
	font-size: 1.3em;
	font-weight: 700;
	color: var(--idrm-text, #222);
	padding-bottom: 12px;
	border-bottom: 2px solid #f0f0f0;
}

.idrm-style-modern .idrm-category-description {
	margin: 8px 0 0;
	color: var(--idrm-text-muted, #888);
	font-size: 0.85em;
}

.idrm-style-modern .idrm-item {
	padding: 12px 0;
	border-bottom: 1px solid #f5f5f5;
	display: flex;
	align-items: flex-start;
	gap: 12px;
}

.idrm-style-modern .idrm-item:last-child {
	border-bottom: none;
}

.idrm-style-modern .idrm-item-thumb {
	width: 56px;
	height: 56px;
	border-radius: 8px;
	overflow: hidden;
	flex-shrink: 0;
}

.idrm-style-modern .idrm-item-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.idrm-style-modern .idrm-item-content {
	flex: 1;
}

.idrm-style-modern .idrm-item-header {
	justify-content: space-between;
}

.idrm-style-modern .idrm-item-name {
	font-weight: 600;
	font-size: 1em;
	color: var(--idrm-text, inherit);
}

.idrm-style-modern .idrm-item-price {
	color: var(--idrm-text, #333);
	font-weight: 700;
}

.idrm-style-modern .idrm-item-description {
	color: var(--idrm-text-muted, #888);
	font-size: 0.85em;
	line-height: 1.5;
}

/* ==========================================================================
   3. Casual Style
   ========================================================================== */

.idrm-style-casual {
	font-family: "Nunito", "Segoe UI", Roboto, sans-serif;
}

.idrm-style-casual .idrm-category-title {
	font-size: 1.4em;
	font-weight: 800;
	color: var(--idrm-text, #333);
	margin-bottom: 12px;
}

.idrm-style-casual .idrm-item {
	padding: 8px 0;
}

.idrm-style-casual .idrm-item-header {
	justify-content: space-between;
}

.idrm-style-casual .idrm-item-name {
	font-weight: 700;
	font-size: 0.95em;
	color: var(--idrm-text, inherit);
}

.idrm-style-casual .idrm-item-price {
	font-weight: 700;
	font-size: 0.95em;
	color: var(--idrm-primary, #e74c3c);
}

.idrm-style-casual .idrm-item-description {
	color: var(--idrm-text-muted, #777);
	font-size: 0.85em;
}

.idrm-style-casual .idrm-featured-badge {
	background: var(--idrm-primary, #e74c3c);
	color: var(--idrm-primary-contrast, #fff);
	border-radius: 12px;
	padding: 2px 10px;
	font-size: 0.65em;
}

.idrm-style-casual .idrm-featured-border {
	border-left-color: var(--idrm-primary, #e74c3c);
}

/* ==========================================================================
   4. Grid Style
   ========================================================================== */

.idrm-style-grid {
	max-width: 1200px;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.idrm-style-grid .idrm-category-title {
	font-size: 1.4em;
	font-weight: 700;
	text-align: center;
	margin-bottom: 20px;
	color: var(--idrm-text, inherit);
}

.idrm-style-grid .idrm-category-description {
	text-align: center;
	margin: -12px 0 20px;
	color: var(--idrm-text-muted, #888);
	font-size: 0.9em;
}

.idrm-grid-items {
	display: grid;
	grid-template-columns: repeat(var(--idrm-grid-columns, 3), 1fr);
	gap: 20px;
}

@media (max-width: 768px) {
	.idrm-grid-items {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.idrm-grid-items {
		grid-template-columns: 1fr;
	}
}

.idrm-grid-card {
	background: #fff;
	border-radius: 10px;
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	transition: transform 0.2s, box-shadow 0.2s;
	position: relative;
}

.idrm-grid-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.idrm-grid-ribbon {
	position: absolute;
	top: 12px;
	right: -6px;
	background: var(--idrm-primary, #f9a825);
	color: var(--idrm-primary-contrast, #fff);
	padding: 4px 12px;
	font-size: 0.7em;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	z-index: 1;
}

.idrm-grid-ribbon::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: -6px;
	border-left: 6px solid #c68400;
	border-bottom: 6px solid transparent;
}

.idrm-grid-image {
	width: 100%;
	height: 180px;
	overflow: hidden;
}

.idrm-grid-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.idrm-grid-body {
	padding: 16px;
}

.idrm-menu .idrm-grid-name {
	margin: 0 0 8px;
	font-size: 1.05em;
	font-weight: 700;
	color: var(--idrm-text, inherit);
}

.idrm-menu .idrm-grid-description {
	margin: 0 0 12px;
	color: var(--idrm-text-muted, #888);
	font-size: 0.85em;
	line-height: 1.5;
}

.idrm-grid-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.idrm-grid-price {
	font-weight: 700;
	font-size: 1.1em;
	color: var(--idrm-text, #333);
}

.idrm-grid-card.idrm-featured-border {
	border: 2px solid var(--idrm-primary, #f9a825);
	padding-left: 0;
}

.idrm-grid-card.idrm-featured-background {
	background: #fffde7;
	padding: 0;
}

/* ==========================================================================
   5. Minimal Style
   ========================================================================== */

.idrm-style-minimal {
	max-width: 700px;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.idrm-style-minimal .idrm-category-title {
	font-size: 1.1em;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: 12px;
	padding-bottom: 8px;
	border-bottom: 1px solid #ddd;
	color: var(--idrm-text, inherit);
}

.idrm-style-minimal .idrm-item {
	padding: 6px 0;
}

.idrm-style-minimal .idrm-item-header {
	justify-content: space-between;
}

.idrm-style-minimal .idrm-item-name {
	font-weight: 500;
	font-size: 0.95em;
	color: var(--idrm-text, inherit);
}

.idrm-style-minimal .idrm-item-price {
	font-weight: 500;
	font-size: 0.95em;
	color: var(--idrm-text, #555);
}

.idrm-style-minimal .idrm-item-description {
	color: var(--idrm-text-muted, #999);
	font-size: 0.82em;
}

.idrm-style-minimal .idrm-featured .idrm-item-name {
	font-weight: 700;
}
