/*
Theme Name: DerbyFlow SEO (Elementor)
Theme URI: https://derbyflow.us
Description: A child theme of Hello Elementor for restaurants. You design every page in Elementor; this theme silently owns the BACKEND SEO — schema.org structured data (Restaurant / LocalBusiness, Menu, Events, FAQ, Breadcrumbs), meta + Open Graph tags, an auto XML sitemap, local landing pages, and live menu/hours/NAP shortcodes — all driven by your DerbyFlow account and kept in sync. Powered by Derby Digital.
Author: Derby Digital
Author URI: https://derbydigital.us
Template: hello-elementor
Version: 1.2.1
Update URI: https://derbyflow.us/derbyflow-theme.json
Text Domain: derbyflow-seo
Requires at least: 6.0
Requires PHP: 7.4
*/

/* Design is handled in Elementor. This child theme adds no visual styles by
   default — only the few utility classes the DerbyFlow shortcodes render with,
   so they inherit your Elementor typography and colors. */

.df-menu { margin: 1.25rem 0; }
.df-menu__section { margin-bottom: 1.75rem; }
.df-menu__section-name { font-weight: 700; letter-spacing: .02em; margin: 0 0 .5rem; }
.df-menu__item { display: flex; justify-content: space-between; gap: 1rem; padding: .4rem 0; border-bottom: 1px dotted rgba(0,0,0,.12); }
.df-menu__item-name { font-weight: 600; }
.df-menu__item-desc { opacity: .75; font-size: .92em; }
.df-menu__item-price { white-space: nowrap; font-variant-numeric: tabular-nums; }
.df-hours { margin: 0; }
.df-hours li { display: flex; justify-content: space-between; gap: 1rem; padding: .15rem 0; }
.df-nap { line-height: 1.6; }
/* Events — branded cards (mirrors the DerbyFlow events page; --df-accent is the brand accent). */
.df-events-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.25rem; margin: 0; padding: 0; }
.df-ev-card { display: flex; flex-direction: column; overflow: hidden; border-radius: 18px; background: #fff; border: 1px solid rgba(16,32,64,.07); box-shadow: 0 12px 32px -14px rgba(16,32,64,.22); }
.df-ev-media { aspect-ratio: 16 / 10; overflow: hidden; background: #eef2f9; }
.df-ev-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.df-ev-body { padding: 1rem 1.1rem 1.15rem; }
.df-ev-when { display: block; font-size: .7rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; color: #5b6b86; }
.df-ev-cat { display: inline-block; margin-top: .45rem; padding: .15rem .6rem; border-radius: 999px; font-size: .64rem; font-weight: 800; letter-spacing: .03em; text-transform: uppercase; color: var(--df-accent, #2D6BFF); background: color-mix(in srgb, var(--df-accent, #2D6BFF) 13%, transparent); }
.df-ev-title { margin: .4rem 0 0; font-size: 1.2rem; line-height: 1.15; font-weight: 800; color: #10203f; }
.df-ev-desc { margin: .35rem 0 0; font-size: .86rem; line-height: 1.45; color: #5b6b86; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.df-ev-adm { display: inline-block; margin-top: .7rem; font-size: .72rem; font-weight: 800; color: var(--df-accent, #2D6BFF); }
/* empty state — a white card so it's readable on any Elementor background */
.df-ev-empty { display: grid; place-items: center; gap: .25rem; padding: 2.5rem 1.25rem; border-radius: 18px; background: #fff; border: 1px solid rgba(16,32,64,.08); box-shadow: 0 12px 32px -16px rgba(16,32,64,.2); text-align: center; }
.df-ev-empty-title { margin: 0; font-size: 1rem; font-weight: 800; color: #10203f; }
.df-ev-empty-sub { margin: 0; font-size: .85rem; color: #5b6b86; }
/* legacy list (older snapshots) */
.df-events { list-style: none; margin: 0; padding: 0; }
.df-events li { padding: .5rem 0; border-bottom: 1px solid rgba(0,0,0,.08); }
.df-btn { display: inline-block; padding: .65rem 1.25rem; border-radius: .5rem; text-decoration: none; font-weight: 700; }
.df-note { font-size: .85em; opacity: .6; }

/* ── Styled menu ([derbyflow_menu]) ──────────────────────────────────────────
   A faithful port of the in-app React menu (src/dev/menu/menu.css + MenuDisplay):
   the SAME .df-menu-canvas markup, data-* attributes and class names, so the live
   WordPress page is pixel-identical to the owner's DerbyFlow Preview. The PHP
   shortcode emits the data-* attrs (template/cols/density/card/divider/align) +
   inline fonts/accent; these rules paint the six templates. Container queries make
   the menu respond to ITS OWN width (it may be embedded in a narrow column or
   full-width), never the browser viewport.

   Scoped reset — neutralise the parent theme's element styles so the menu renders
   the same here as in-app (Tailwind's preflight does this in the app). */
.df-menu-canvas, .df-menu-canvas *, .df-menu-canvas *::before, .df-menu-canvas *::after { box-sizing: border-box; }
.df-menu-canvas h2, .df-menu-canvas h3, .df-menu-canvas p { margin: 0; padding: 0; }
.df-menu-canvas img { display: block; max-width: 100%; }
.df-menu-canvas button.df-menu-pill { margin: 0; border: 0; cursor: pointer; -webkit-appearance: none; appearance: none; }
.df-menu-page { min-width: 0; }

.df-menu-canvas { container-type: inline-size; border-radius: 1rem; padding: 1rem; }
@container (min-width: 680px) { .df-menu-canvas { padding: 1.75rem; } }

/* decorative header */
.df-menu-header { text-align: center; margin-bottom: 1.5rem; }
.df-menu-header-left { text-align: left; }
.df-menu-logo { height: 56px; width: auto; max-width: 200px; object-fit: contain; margin-bottom: 0.6rem; }
.df-menu-header:not(.df-menu-header-left) .df-menu-logo { margin-left: auto; margin-right: auto; }
.df-menu-title { font-size: 26px; line-height: 1.1; letter-spacing: 0.02em; color: #141414; }
@container (min-width: 680px) { .df-menu-title { font-size: 34px; } }
.df-menu-tagline { margin-top: 0.35rem; font-size: 13px; font-style: italic; color: #666; }

/* menu switcher pills — substantial tabs at the scale of a real site's switcher */
.df-menu-pills { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.75rem; margin-bottom: 1.5rem; }
.df-menu-canvas[data-align='left'] .df-menu-pills { justify-content: flex-start; }
.df-menu-pill { border-radius: 10px; padding: 0.55rem 1.65rem; font-size: 16px; font-weight: 500; letter-spacing: 0.03em; line-height: 1.2; background: #1b1d24; color: #ffffff; box-shadow: 0 6px 18px -12px rgba(11, 26, 59, 0.5); transition: background 0.3s ease, color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease; }
@container (min-width: 600px) { .df-menu-pill { padding: 0.5rem 1.9rem; font-size: 21px; } }
.df-menu-pill[data-active='true'] { background: var(--df-accent, #1b1d24); color: var(--df-pill-active-text, #ffffff); box-shadow: 0 10px 26px -12px color-mix(in srgb, var(--df-accent, #1b1d24) 60%, transparent); }
.df-menu-pill:not([data-active='true']):hover { background: var(--df-accent, #1b1d24); color: var(--df-pill-active-text, #ffffff); transform: translateY(-2px); box-shadow: 0 12px 26px -12px color-mix(in srgb, var(--df-accent, #1b1d24) 55%, transparent); }

/* active menu blurb */
.df-menu-blurb { max-width: 42rem; margin: 0 auto 1.75rem; text-align: center; font-size: 13px; font-style: italic; line-height: 1.6; color: #555; }
.df-menu-canvas[data-align='left'] .df-menu-blurb { margin-left: 0; text-align: left; }

/* the grid: one column, two only when the CONTAINER is wide */
.df-menu-grid { column-count: 1; column-gap: 1.25rem; }
.df-menu-canvas[data-cols='auto'] .df-menu-grid, .df-menu-canvas[data-cols='2'] .df-menu-grid { column-count: 1; }
@container (min-width: 600px) { .df-menu-canvas[data-cols='auto'] .df-menu-grid { column-count: 2; } }
@container (min-width: 520px) { .df-menu-canvas[data-cols='2'] .df-menu-grid { column-count: 2; } }
.df-menu-canvas[data-cols='1'] .df-menu-grid { column-count: 1; }
/* a lone category centers instead of stranding in the left column */
.df-menu-canvas:not([data-template='sicilian']):not([data-cols='1']) .df-menu-grid[data-single='true'] { column-count: 1; max-width: 40rem; margin-inline: auto; }

/* category card: card / flat / bordered */
.df-card { display: inline-block; width: 100%; break-inside: avoid; border-radius: 1rem; margin-bottom: 1.25rem; padding: 1.25rem; }
@container (min-width: 680px) { .df-card { padding: 2rem; } }
.df-menu-canvas[data-card='card'] .df-card { background: #ffffff; box-shadow: 0 18px 50px -28px rgba(11, 26, 59, 0.35); }
.df-menu-canvas[data-card='flat'] .df-card { background: transparent; }
.df-menu-canvas[data-card='bordered'] .df-card { background: #ffffff; border: 1.5px solid var(--df-accent, #141414); }

/* density */
.df-menu-canvas[data-density='compact'] .df-card { padding: 1rem 1.1rem; margin-bottom: 0.9rem; }
.df-menu-canvas[data-density='roomy'] .df-card { padding: 1.75rem; }
@container (min-width: 680px) { .df-menu-canvas[data-density='roomy'] .df-card { padding: 2.6rem; } }
.df-menu-canvas[data-density='compact'] .df-menu-grid { column-gap: 1rem; }
.df-menu-canvas[data-density='roomy'] .df-menu-grid { column-gap: 1.75rem; }
.df-menu-canvas[data-density='roomy'] .df-card { margin-bottom: 1.75rem; }

/* category title + flourish */
.df-menu-cat { font-size: 23px; line-height: 1.15; letter-spacing: 0.04em; font-weight: 400; color: #141414; overflow-wrap: break-word; }
@container (min-width: 680px) { .df-menu-cat { font-size: 30px; } }
.df-menu-canvas[data-template='bold'] .df-cat { border-left: 5px solid var(--df-accent, #141414); padding-left: 0.65rem; font-weight: 600; letter-spacing: 0.02em; }
.df-flourish { display: block; margin-top: 0.35rem; font-size: 14px; color: var(--df-accent, #141414); }
.df-menu-canvas[data-align='center'] .df-flourish { text-align: center; }
.df-cat-note { max-width: 28rem; margin-top: 0.5rem; font-size: 13px; line-height: 1.6; color: #555; }

/* item list + dividers + rows */
.df-itemlist { margin-top: 1.25rem; }
.df-menu-canvas[data-divider='ruled'] .df-itemlist { border-left: 1px solid rgba(0, 0, 0, 0.1); padding-left: 1.25rem; }
.df-item { padding: 1rem 0; }
.df-item:first-child { padding-top: 0.25rem; }
.df-menu-canvas[data-divider='ruled'] .df-item + .df-item, .df-menu-canvas[data-divider='line'] .df-item + .df-item { border-top: 1px solid rgba(0, 0, 0, 0.1); }
.df-menu-canvas[data-density='compact'] .df-item { padding: 0.6rem 0; }
.df-menu-canvas[data-density='roomy'] .df-item { padding: 1.35rem 0; }
.df-item-row { display: flex; align-items: baseline; justify-content: space-between; gap: 0.75rem; }
.df-menu-name { font-size: 17px; font-weight: 300; color: #141414; min-width: 0; overflow-wrap: break-word; }
@container (min-width: 680px) { .df-menu-name { font-size: 20px; } }
.df-menu-price { font-size: 16px; font-weight: 600; flex-shrink: 0; font-variant-numeric: tabular-nums; }
.df-item-desc { margin-top: 0.375rem; font-size: 13px; line-height: 1.6; color: #4a4a4a; }

/* item photos */
.df-item-photo { margin-top: 0.875rem; width: 100%; border-radius: 0.5rem; object-fit: cover; }
.df-photo-sm { max-height: 9rem; }
.df-photo-md { max-height: 14rem; }
.df-photo-lg { max-height: 20rem; }

/* Sicilian template — dark marble + gold, framed, serif caps (a self-contained
   DARK scheme; the other five are light) */
.df-menu-canvas[data-template='sicilian'] { position: relative; color: #e7dfd4; border-radius: 3px; padding: clamp(2rem, 5.5vw, 4.5rem); background-color: #0b0a09; background-image: radial-gradient(130% 90% at 18% 8%, rgba(201, 160, 90, 0.07), transparent 55%), radial-gradient(120% 80% at 85% 92%, rgba(201, 160, 90, 0.05), transparent 50%), repeating-linear-gradient(118deg, rgba(255, 255, 255, 0.012) 0 2px, transparent 2px 26px), repeating-linear-gradient(64deg, rgba(255, 255, 255, 0.01) 0 1px, transparent 1px 34px), linear-gradient(135deg, #110f0d 0%, #0a0908 45%, #15110c 100%); border: 1px solid color-mix(in srgb, var(--df-accent, #c89a4b) 70%, transparent); }
.df-menu-canvas[data-template='sicilian']::after { content: ''; position: absolute; inset: 11px; border: 1px solid color-mix(in srgb, var(--df-accent, #c89a4b) 42%, transparent); border-radius: 2px; pointer-events: none; }
.df-frame { position: absolute; inset: 0; pointer-events: none; z-index: 2; }
.df-corner { position: absolute; width: 30px; height: 30px; color: var(--df-accent, #c89a4b); }
.df-corner svg { display: block; width: 100%; height: 100%; }
.df-corner-tl { top: 17px; left: 17px; }
.df-corner-tr { top: 17px; right: 17px; transform: rotate(90deg); }
.df-corner-br { right: 17px; bottom: 17px; transform: rotate(180deg); }
.df-corner-bl { bottom: 17px; left: 17px; transform: rotate(270deg); }
.df-menu-canvas[data-template='sicilian'] .df-menu-grid { column-count: 1 !important; }
.df-menu-canvas[data-template='sicilian'] .df-card { background: transparent !important; box-shadow: none !important; border: none !important; padding: 0 !important; margin-bottom: 3.25rem; }
.df-menu-canvas[data-template='sicilian'] .df-itemlist { display: grid; grid-template-columns: 1fr; gap: 1.6rem 3rem; border: none !important; padding: 0 !important; margin-top: 1.9rem; }
@container (min-width: 560px) { .df-menu-canvas[data-template='sicilian'] .df-itemlist { grid-template-columns: 1fr 1fr; } }
@container (min-width: 900px) { .df-menu-canvas[data-template='sicilian'] .df-itemlist { grid-template-columns: 1fr 1fr 1fr; } }
.df-menu-canvas[data-template='sicilian'] .df-item { padding: 0 !important; border: none !important; }
.df-menu-canvas[data-template='sicilian'] .df-cat { display: flex; align-items: center; justify-content: center; gap: 1.5rem; text-align: center; color: var(--df-accent, #c89a4b); font-weight: 500; letter-spacing: 0.3em; }
.df-menu-canvas[data-template='sicilian'] .df-cat::before, .df-menu-canvas[data-template='sicilian'] .df-cat::after { content: ''; flex: 1; max-width: 30%; height: 1px; }
.df-menu-canvas[data-template='sicilian'] .df-cat::before { background: linear-gradient(90deg, transparent, var(--df-accent, #c89a4b)); }
.df-menu-canvas[data-template='sicilian'] .df-cat::after { background: linear-gradient(90deg, var(--df-accent, #c89a4b), transparent); }
.df-menu-canvas[data-template='sicilian'] .df-cat-note { margin: 0.75rem auto 0; text-align: center; color: #b7afa2; }
.df-menu-canvas[data-template='sicilian'] .df-item-name { color: #e7dfd4; font-weight: 600; text-transform: uppercase; letter-spacing: 0.07em; }
.df-menu-canvas[data-template='sicilian'] .df-item-desc { color: #b3aa9d; }
.df-menu-canvas[data-template='sicilian'] .df-menu-blurb { color: #cfc7ba; }
.df-menu-canvas[data-template='sicilian'] .df-menu-title { color: #e7dfd4; }
.df-menu-canvas[data-template='sicilian'] .df-menu-tagline { color: #b3aa9d; }
.df-menu-canvas[data-template='sicilian'] .df-menu-pill { box-shadow: none; border: 1px solid color-mix(in srgb, var(--df-accent, #c89a4b) 55%, transparent); }
