/* ==========================================================================
   Divi Restaurant Menu Cards v2.0.0 — styles (frontend + VB)
   ========================================================================== */

/* --------------------------------------------------------------------------
   CSS custom properties — defaults (overridden via inline style per module)
   -------------------------------------------------------------------------- */
.drmc-module {
	--drmc-card-bg: #ffffff;
	--drmc-radius: 8px;
	--drmc-padding: 16px;
	--drmc-gap: 16px;
	--drmc-title-color: #1a1a1a;
	--drmc-desc-color: #666666;
	--drmc-price-color: #2c7a4b;
	--drmc-section-title-color: #1a1a1a;
	--drmc-menu-title-color: #1a1a1a;
	--drmc-badge-bg: #e8a838;
	--drmc-badge-color: #ffffff;
	--drmc-tag-bg: #eef5ee;
	/* Typography size vars (set by module attributes) */
	--drmc-menu-title-size: 2em;
	--drmc-section-title-size: 1.4em;
	--drmc-item-name-size: 1em;
	--drmc-item-desc-size: 0.875em;
	--drmc-item-price-size: 1em;
	--drmc-tag-color: #2d6b2d;
	--drmc-variation-color: #555555;
	--drmc-divider-color: #e0e0e0;
	box-sizing: border-box;
	font-family: inherit;
}

/* --------------------------------------------------------------------------
   Menu header
   -------------------------------------------------------------------------- */
.drmc-menu-header {
	text-align: center;
	margin-bottom: 40px;
}

.drmc-menu-title {
	font-size: var(--drmc-menu-title-size, 2em);
	font-weight: 700;
	color: var(--drmc-menu-title-color);
	margin: 0 0 8px;
	line-height: 1.2;
}

.drmc-menu-subtitle {
	font-size: 1em;
	color: var(--drmc-desc-color);
	margin: 0 0 20px;
}

.drmc-menu-divider {
	width: 60px;
	height: 3px;
	background: var(--drmc-price-color);
	margin: 0 auto;
	border-radius: 2px;
}

/* --------------------------------------------------------------------------
   Section
   -------------------------------------------------------------------------- */
.drmc-section {
	margin-bottom: 48px;
}

.drmc-section:last-child {
	margin-bottom: 0;
}

.drmc-section-header {
	margin-bottom: 24px;
}

.drmc-section-title {
	font-size: var(--drmc-section-title-size, 1.4em);
	font-weight: 700;
	color: var(--drmc-section-title-color);
	margin: 0 0 12px;
	padding-bottom: 12px;
	border-bottom: 2px solid var(--drmc-divider-color);
	line-height: 1.2;
}

/* --------------------------------------------------------------------------
   Items grid
   -------------------------------------------------------------------------- */
.drmc-items-grid {
	display: grid;
	gap: var(--drmc-gap);
}

.drmc-cols-1 .drmc-items-grid {
	grid-template-columns: 1fr;
}

.drmc-cols-2 .drmc-items-grid {
	grid-template-columns: repeat(2, 1fr);
}

.drmc-cols-3 .drmc-items-grid {
	grid-template-columns: repeat(3, 1fr);
}

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

@media ( min-width: 769px ) and ( max-width: 1024px ) {
	.drmc-cols-3 .drmc-items-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* --------------------------------------------------------------------------
   Item card
   -------------------------------------------------------------------------- */
.drmc-item {
	background: var(--drmc-card-bg);
	border-radius: var(--drmc-radius);
	padding: var(--drmc-padding);
	display: flex;
	flex-direction: column;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	box-sizing: border-box;
}

.drmc-shadow .drmc-item {
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.drmc-shadow .drmc-item:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
}

.drmc-item-body {
	flex: 1;
}

.drmc-item-header {
	display: flex;
	align-items: baseline;
	gap: 8px;
	margin-bottom: 8px;
}

.drmc-item-name {
	font-size: var(--drmc-item-name-size, 1em);
	font-weight: 600;
	color: var(--drmc-title-color);
	flex-shrink: 0;
	line-height: 1.3;
}

.drmc-item-dots {
	flex: 1;
	border-bottom: 1.5px dotted #cccccc;
	margin-bottom: 4px;
	min-width: 16px;
}

.drmc-item-price {
	font-size: var(--drmc-item-price-size, 1em);
	font-weight: 700;
	color: var(--drmc-price-color);
	flex-shrink: 0;
	white-space: nowrap;
}

.drmc-item-desc {
	font-size: var(--drmc-item-desc-size, 0.875em);
	color: var(--drmc-desc-color);
	margin: 0 0 10px;
	line-height: 1.5;
}

/* --------------------------------------------------------------------------
   Variations
   -------------------------------------------------------------------------- */
.drmc-item-variations {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 10px;
}

.drmc-variation {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	background: rgba(0, 0, 0, 0.04);
	border-radius: 4px;
	padding: 3px 8px;
	font-size: 0.8em;
}

.drmc-variation-name {
	color: var(--drmc-desc-color);
}

.drmc-variation-sep {
	color: #aaaaaa;
}

.drmc-variation-price {
	font-weight: 600;
	color: var(--drmc-price-color);
}

/* --------------------------------------------------------------------------
   Item footer (badge + tags)
   -------------------------------------------------------------------------- */
.drmc-item-footer {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
	margin-top: 10px;
	padding-top: 10px;
	border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.drmc-item-badge {
	display: inline-block;
	background: var(--drmc-badge-bg);
	color: var(--drmc-badge-color);
	font-size: 0.7em;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 3px 8px;
	border-radius: 3px;
	white-space: nowrap;
}

/* --------------------------------------------------------------------------
   Dietary tags
   -------------------------------------------------------------------------- */
.drmc-item-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
}

.drmc-tag {
	display: inline-flex;
	align-items: center;
	gap: 3px;
	background: var(--drmc-tag-bg);
	color: var(--drmc-tag-color);
	font-size: 0.75em;
	font-weight: 500;
	padding: 2px 7px;
	border-radius: 100px;
	white-space: nowrap;
}

.drmc-tag-icon {
	font-size: 0.9em;
	line-height: 1;
}

.drmc-tag--vegan       { --drmc-tag-bg: #e8f5e9; --drmc-tag-color: #2e7d32; }
.drmc-tag--vegetarian  { --drmc-tag-bg: #e8f5e9; --drmc-tag-color: #388e3c; }
.drmc-tag--gf          { --drmc-tag-bg: #fff8e1; --drmc-tag-color: #f57f17; }
.drmc-tag--spicy       { --drmc-tag-bg: #fce4ec; --drmc-tag-color: #c62828; }
.drmc-tag--df          { --drmc-tag-bg: #e3f2fd; --drmc-tag-color: #1565c0; }
.drmc-tag--nf          { --drmc-tag-bg: #fbe9e7; --drmc-tag-color: #bf360c; }
.drmc-tag--halal       { --drmc-tag-bg: #e0f7fa; --drmc-tag-color: #00695c; }
.drmc-tag--organic     { --drmc-tag-bg: #f1f8e9; --drmc-tag-color: #33691e; }
.drmc-tag--custom      { --drmc-tag-bg: #eeeeee; --drmc-tag-color: #424242; }


/* ==========================================================================
   STYLE: CLASSIC
   Clean white cards, minimal borders, timeless restaurant feel
   ========================================================================== */
.drmc-style-classic {
	--drmc-card-bg: #ffffff;
	--drmc-price-color: #1a6b3c;
	--drmc-badge-bg: #c8953a;
}

.drmc-style-classic .drmc-section-title {
	font-family: Georgia, 'Times New Roman', serif;
	font-size: 1.3em;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

.drmc-style-classic .drmc-item {
	border: 1px solid #eeeeee;
}

.drmc-style-classic .drmc-menu-title {
	font-family: Georgia, 'Times New Roman', serif;
	font-style: italic;
}

.drmc-style-classic .drmc-menu-divider {
	background: #c8953a;
}


/* ==========================================================================
   STYLE: MODERN
   Dark theme, bold accents, contemporary bistro feel
   ========================================================================== */
.drmc-style-modern {
	--drmc-card-bg: #1e1e2e;
	--drmc-title-color: #e8e8f0;
	--drmc-desc-color: #9090a8;
	--drmc-price-color: #7ec8a4;
	--drmc-section-title-color: #e8e8f0;
	--drmc-menu-title-color: #e8e8f0;
	--drmc-badge-bg: #7ec8a4;
	--drmc-badge-color: #0d1117;
	--drmc-tag-bg: rgba(126, 200, 164, 0.15);
	--drmc-tag-color: #7ec8a4;
	--drmc-divider-color: #2d2d40;
	--drmc-variation-color: #9090a8;
	background-color: #0d1117;
	padding: 40px;
	border-radius: 12px;
}

.drmc-style-modern .drmc-item {
	border: 1px solid #2d2d40;
}

.drmc-style-modern .drmc-item-dots {
	border-color: #2d2d40;
}

.drmc-style-modern .drmc-item-footer {
	border-color: rgba(255, 255, 255, 0.06);
}

.drmc-style-modern .drmc-variation {
	background: rgba(255, 255, 255, 0.06);
}

.drmc-style-modern .drmc-variation-name {
	color: #9090a8;
}

.drmc-style-modern .drmc-section-title {
	font-size: 0.85em;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #7ec8a4;
	border-bottom-color: #2d2d40;
}

.drmc-style-modern .drmc-menu-divider {
	background: #7ec8a4;
}

.drmc-style-modern .drmc-tag--vegan,
.drmc-style-modern .drmc-tag--vegetarian,
.drmc-style-modern .drmc-tag--gf,
.drmc-style-modern .drmc-tag--spicy,
.drmc-style-modern .drmc-tag--df,
.drmc-style-modern .drmc-tag--nf,
.drmc-style-modern .drmc-tag--halal,
.drmc-style-modern .drmc-tag--organic,
.drmc-style-modern .drmc-tag--custom {
	background: rgba(255, 255, 255, 0.08);
	color: #b0b0c8;
}


/* ==========================================================================
   STYLE: ELEGANT
   Cream & gold, fine dining, serif typography
   ========================================================================== */
.drmc-style-elegant {
	--drmc-card-bg: #faf7f2;
	--drmc-title-color: #2c2018;
	--drmc-desc-color: #7a6a5a;
	--drmc-price-color: #a0762a;
	--drmc-section-title-color: #2c2018;
	--drmc-menu-title-color: #2c2018;
	--drmc-badge-bg: #a0762a;
	--drmc-badge-color: #faf7f2;
	--drmc-divider-color: #d4b896;
}

.drmc-style-elegant .drmc-menu-title,
.drmc-style-elegant .drmc-section-title,
.drmc-style-elegant .drmc-item-name {
	font-family: Georgia, 'Palatino Linotype', Palatino, serif;
}

.drmc-style-elegant .drmc-menu-title {
	font-style: italic;
	font-size: 2.2em;
	letter-spacing: 0.02em;
}

.drmc-style-elegant .drmc-section-title {
	font-size: 1.2em;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	font-style: italic;
	border-bottom: 1px solid #d4b896;
}

.drmc-style-elegant .drmc-menu-divider {
	width: 80px;
	height: 1px;
	background: #a0762a;
}

.drmc-style-elegant .drmc-item {
	border: 1px solid #e8dfd4;
	background: #faf7f2;
}

.drmc-style-elegant .drmc-item-dots {
	border-color: #d4b896;
}

.drmc-style-elegant .drmc-item-footer {
	border-top-color: #e8dfd4;
}

.drmc-style-elegant .drmc-variation {
	background: rgba(160, 118, 42, 0.08);
}

.drmc-style-elegant .drmc-variation-price {
	color: #a0762a;
}

.drmc-style-elegant .drmc-section-header::after {
	content: '❧';
	display: block;
	text-align: center;
	color: #a0762a;
	font-size: 1.2em;
	margin-top: 6px;
}


/* ==========================================================================
   STYLE: MINIMAL
   Pure text layout, no cards, clean dotted price alignment
   ========================================================================== */
.drmc-style-minimal {
	--drmc-card-bg: transparent;
	--drmc-price-color: #1a1a1a;
	--drmc-badge-bg: #1a1a1a;
}

.drmc-style-minimal .drmc-item {
	background: transparent;
	padding-left: 0;
	padding-right: 0;
	padding-top: 0;
	padding-bottom: 14px;
	border-bottom: 1px solid #eeeeee;
	border-radius: 0;
	box-shadow: none !important;
}

.drmc-style-minimal .drmc-item:hover {
	transform: none;
	box-shadow: none !important;
}

.drmc-style-minimal .drmc-section-title {
	text-align: center;
	font-size: 0.8em;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	border-bottom: none;
	border-top: 1px solid #1a1a1a;
	padding-top: 16px;
}

.drmc-style-minimal .drmc-item-name {
	font-weight: 500;
}

.drmc-style-minimal .drmc-item-footer {
	border-top: none;
	padding-top: 4px;
}

.drmc-style-minimal .drmc-menu-divider {
	background: #1a1a1a;
}

.drmc-style-minimal .drmc-variation {
	background: transparent;
	padding: 0;
	font-size: 0.8em;
}

.drmc-style-minimal .drmc-variation-sep {
	display: none;
}


/* ==========================================================================
   STYLE: CHALKBOARD
   Dark green/charcoal background, chalk-white text, bistro/café feel
   ========================================================================== */
.drmc-style-chalkboard {
	--drmc-card-bg: rgba(255, 255, 255, 0.07);
	--drmc-title-color: #f0ece4;
	--drmc-desc-color: #c8c0b4;
	--drmc-price-color: #f5d26a;
	--drmc-section-title-color: #f0ece4;
	--drmc-menu-title-color: #f0ece4;
	--drmc-badge-bg: #f5d26a;
	--drmc-badge-color: #1e2d20;
	--drmc-tag-bg: rgba(245, 210, 106, 0.15);
	--drmc-tag-color: #f5d26a;
	--drmc-divider-color: rgba(255, 255, 255, 0.2);
	background-color: #1e2d20;
	padding: 40px;
	border-radius: 4px;
}

.drmc-style-chalkboard .drmc-item {
	border: 1px dashed rgba(255, 255, 255, 0.15);
}

.drmc-style-chalkboard .drmc-item-dots {
	border-color: rgba(255, 255, 255, 0.2);
}

.drmc-style-chalkboard .drmc-item-footer {
	border-color: rgba(255, 255, 255, 0.1);
}

.drmc-style-chalkboard .drmc-variation {
	background: rgba(255, 255, 255, 0.07);
}

.drmc-style-chalkboard .drmc-variation-name {
	color: #c8c0b4;
}

.drmc-style-chalkboard .drmc-variation-price {
	color: #f5d26a;
}

.drmc-style-chalkboard .drmc-menu-title {
	font-family: Georgia, serif;
	font-style: italic;
}

.drmc-style-chalkboard .drmc-section-title {
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-size: 1em;
	color: #f5d26a;
	border-bottom-color: rgba(245, 210, 106, 0.3);
}

.drmc-style-chalkboard .drmc-menu-divider {
	background: #f5d26a;
}

.drmc-style-chalkboard .drmc-tag--vegan,
.drmc-style-chalkboard .drmc-tag--vegetarian,
.drmc-style-chalkboard .drmc-tag--gf,
.drmc-style-chalkboard .drmc-tag--spicy,
.drmc-style-chalkboard .drmc-tag--df,
.drmc-style-chalkboard .drmc-tag--nf,
.drmc-style-chalkboard .drmc-tag--halal,
.drmc-style-chalkboard .drmc-tag--organic,
.drmc-style-chalkboard .drmc-tag--custom {
	background: rgba(245, 210, 106, 0.12);
	color: #f5d26a;
}
