.elementor-kit-6{--e-global-color-primary:#6EC1E4;--e-global-color-secondary:#54595F;--e-global-color-text:#7A7A7A;--e-global-color-accent:#61CE70;--e-global-typography-primary-font-family:"Roboto";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Roboto Slab";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Roboto";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;}.elementor-kit-6 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}
/* Start custom CSS *//*
Theme Name: Firm Elementor Theme Styles
Description: WordPress/Elementor stylesheet based on the React app visual system.
Source app styles: src/styles/global.css, CardView.css, ProductDetails.css, Login.css,
NavigationBar.css, Meals.css, SupportTickets.css, Admin.css, StoreBranding.css.

Use:
1. Paste into Elementor > Site Settings > Custom CSS, or
2. Paste into Appearance > Customize > Additional CSS, or
3. Enqueue/copy as the style.css of a child theme.
*/

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap");

:root {
  /* App fonts */
  --firm-font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --firm-font-system: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --firm-font-display: Georgia, "Times New Roman", serif;
  --firm-font-mono: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;

  /* Primary public brand palette from the React app */
  --firm-bg: #f7f3ec;
  --firm-surface: #fffdf8;
  --firm-surface-strong: #ffffff;
  --firm-surface-soft: #fbf6ed;
  --firm-paper: #ede1d1;
  --firm-text: #172119;
  --firm-text-soft: #2e352f;
  --firm-muted: #6f6a60;
  --firm-muted-2: #948c7e;
  --firm-border: #e7dccc;
  --firm-border-strong: #d5c4af;
  --firm-primary: #214734;
  --firm-primary-600: #173326;
  --firm-primary-hover: #225238;
  --firm-accent: #c89a3c;
  --firm-clay: #a86444;
  --firm-danger: #ef4444;
  --firm-danger-strong: #b42318;
  --firm-warning: #b7791f;
  --firm-info: #0d6efd;
  --firm-info-hover: #0a58ca;
  --firm-success: #28a745;

  /* Admin/reporting palette preserved from the React app */
  --firm-admin-bg: #f6f8fb;
  --firm-admin-card: #ffffff;
  --firm-admin-text: #0f172a;
  --firm-admin-muted: #475569;
  --firm-admin-muted-2: #64748b;
  --firm-admin-border: #e5e7eb;
  --firm-admin-primary: #2563eb;
  --firm-admin-primary-700: #1d4ed8;
  --firm-admin-ring: #93c5fd;

  /* Retailer/store branding */
  --firm-coles: #d71920;
  --firm-coles-strong: #9f171b;
  --firm-coles-bg: #fde8ea;
  --firm-woolworths: #138540;
  --firm-woolworths-strong: #176d35;
  --firm-woolworths-bg: #e5f6df;
  --firm-aldi: #004b93;
  --firm-aldi-strong: #0f4c81;
  --firm-aldi-bg: #e5f0ff;
  --firm-iga: #a50034;
  --firm-iga-strong: #7f0028;
  --firm-iga-bg: #ffe8ee;
  --firm-amazon: #111827;
  --firm-amazon-bg: #fff4df;

  /* Sizes, spacing, radii */
  --firm-container: 1200px;
  --firm-container-wide: 1540px;
  --firm-radius: 8px;
  --firm-radius-control: 10px;
  --firm-radius-admin: 12px;
  --firm-radius-pill: 999px;
  --firm-page-pad-x: 16px;
  --firm-section-pad-y: clamp(48px, 8vw, 92px);
  --firm-card-pad: clamp(22px, 3.4vw, 36px);
  --firm-control-height: 52px;
  --firm-button-height: 42px;
  --firm-nav-height: 60px;
  --firm-transition: 0.18s ease;
  --firm-transition-fast: 0.05s ease;
  --firm-focus: rgba(33, 71, 52, 0.18);
  --firm-shadow: 0 22px 60px rgba(47, 39, 29, 0.12);
  --firm-shadow-soft: 0 12px 30px rgba(47, 39, 29, 0.08);
  --firm-shadow-control: 0 14px 28px rgba(18, 63, 42, 0.18);
  --firm-grad-primary: linear-gradient(135deg, #173f2a, #25563b);
  --firm-page-bg:
    radial-gradient(circle at 50% 0, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0) 420px),
    linear-gradient(180deg, rgba(238, 231, 220, 0.86), rgba(250, 248, 244, 0.8) 430px),
    var(--firm-bg);

  /* Elementor global variable aliases */
  --e-global-color-primary: var(--firm-primary);
  --e-global-color-secondary: var(--firm-clay);
  --e-global-color-text: var(--firm-text);
  --e-global-color-accent: var(--firm-accent);
  --e-global-color-muted: var(--firm-muted);
  --e-global-color-border: var(--firm-border);
  --e-global-typography-primary-font-family: var(--firm-font-display);
  --e-global-typography-secondary-font-family: var(--firm-font-sans);
  --e-global-typography-text-font-family: var(--firm-font-sans);
  --e-global-typography-accent-font-family: var(--firm-font-sans);
}

html {
  scroll-behavior: smooth;
}

body,
.elementor-kit,
.elementor-widget-text-editor,
.elementor-widget-theme-post-content {
  margin: 0;
  background: var(--firm-page-bg);
  color: var(--firm-text);
  font-family: var(--firm-font-sans);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

::selection {
  background: rgba(200, 154, 60, 0.28);
  color: var(--firm-text);
}

a,
.elementor a {
  color: var(--firm-primary);
  font-weight: 800;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

a:hover,
a:focus,
.elementor a:hover,
.elementor a:focus {
  color: var(--firm-primary-600);
}

img,
svg,
video {
  max-width: 100%;
  height: auto;
}

/* Page layout */
.site,
.site-main,
.elementor-location-single,
.elementor-location-archive,
.firm-page {
  background: var(--firm-page-bg);
  color: var(--firm-text);
}

.firm-container,
.elementor-section.firm-container > .elementor-container,
.e-con.firm-container {
  width: 100%;
  max-width: var(--firm-container);
  margin-inline: auto;
  padding-inline: var(--firm-page-pad-x);
}

.firm-container-wide,
.elementor-section.firm-container-wide > .elementor-container,
.e-con.firm-container-wide {
  width: 100%;
  max-width: var(--firm-container-wide);
  margin-inline: auto;
  padding-inline: var(--firm-page-pad-x);
}

.firm-section,
.e-con.firm-section,
.elementor-section.firm-section {
  padding-block: var(--firm-section-pad-y);
}

.firm-section-soft {
  background:
    radial-gradient(circle at 80% 0, rgba(255, 255, 255, 0.82), transparent 380px),
    linear-gradient(135deg, rgba(255, 253, 248, 0.98), rgba(251, 246, 237, 0.92)),
    var(--firm-surface);
}

/* Typography */
h1,
h2,
h3,
.elementor-heading-title,
.firm-display,
.firm-heading {
  margin-block: 0 0.35em;
  color: var(--firm-text);
  font-family: var(--firm-font-display);
  font-weight: 500;
  letter-spacing: 0;
}

h1,
.firm-h1 {
  max-width: 780px;
  font-size: clamp(3rem, 7vw, 4.2rem);
  line-height: 0.98;
}

h2,
.firm-h2 {
  font-size: clamp(2.15rem, 4.8vw, 3.2rem);
  line-height: 1;
}

h3,
.firm-h3 {
  font-size: clamp(1.45rem, 3vw, 2.1rem);
  line-height: 1.08;
}

h4,
.firm-h4 {
  color: var(--firm-text);
  font-family: var(--firm-font-sans);
  font-size: 1.18rem;
  font-weight: 850;
  line-height: 1.25;
}

p,
.firm-copy {
  color: var(--firm-text-soft);
  font-size: 1rem;
  font-weight: 650;
  line-height: 1.55;
}

.firm-lede {
  max-width: 660px;
  color: var(--firm-text-soft);
  font-size: clamp(1rem, 1.8vw, 1.15rem);
  font-weight: 750;
  line-height: 1.45;
}

.firm-eyebrow,
.elementor-widget-heading.firm-eyebrow .elementor-heading-title {
  display: inline-flex;
  margin-bottom: 10px;
  color: var(--firm-clay);
  font-family: var(--firm-font-sans);
  font-size: 0.82rem;
  font-weight: 850;
  letter-spacing: 0;
  line-height: 1.2;
  text-transform: uppercase;
}

.firm-muted {
  color: var(--firm-muted);
}

.firm-small {
  font-size: 0.88rem;
  font-weight: 750;
  line-height: 1.35;
}

/* Hero sections */
.firm-hero,
.e-con.firm-hero,
.elementor-section.firm-hero {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(91, 72, 48, 0.16);
  border-radius: var(--firm-radius);
  background:
    radial-gradient(circle at 78% 16%, rgba(255, 255, 255, 0.9) 0 13%, rgba(255, 255, 255, 0.35) 34%, transparent 54%),
    linear-gradient(135deg, rgba(255, 253, 248, 0.98), rgba(241, 230, 212, 0.9)),
    var(--firm-surface);
  box-shadow: var(--firm-shadow);
}

.firm-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(90deg, rgba(200, 154, 60, 0.08), transparent 34%),
    repeating-linear-gradient(90deg, rgba(91, 72, 48, 0.025) 0 1px, transparent 1px 34px);
}

.firm-hero > *,
.firm-hero .elementor-container,
.firm-hero .e-con-inner {
  position: relative;
  z-index: 1;
}

.firm-hero-content,
.e-con.firm-hero-content {
  display: grid;
  gap: 16px;
  align-content: center;
  min-height: 340px;
  padding: clamp(30px, 5vw, 56px);
}

.firm-brand-panel {
  position: relative;
  overflow: hidden;
  min-height: min(720px, 82vh);
  padding: clamp(42px, 7vw, 86px);
  background:
    radial-gradient(ellipse at 8% 4%, rgba(226, 244, 214, 0.82) 0%, rgba(206, 231, 192, 0.62) 16%, rgba(178, 211, 163, 0.35) 36%, transparent 78%),
    radial-gradient(ellipse at 52% 82%, rgba(255, 235, 177, 0.82) 0%, rgba(239, 216, 154, 0.62) 18%, rgba(219, 199, 134, 0.42) 39%, transparent 88%),
    linear-gradient(180deg, #a7c79f 0%, #bdd8b4 17%, #d6e5c7 39%, #eee5c0 62%, #dfc389 86%, #b99155 100%);
}

.firm-brand-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255, 253, 248, 0.22), transparent 38%),
    repeating-linear-gradient(90deg, rgba(91, 72, 48, 0.035) 0 1px, transparent 1px 34px);
}

.firm-brand-panel > * {
  position: relative;
  z-index: 1;
}

/* Cards and panels */
.firm-card,
.elementor-widget-container.firm-card,
.e-con.firm-card {
  overflow: hidden;
  border: 1px solid var(--firm-border);
  border-radius: var(--firm-radius);
  background:
    radial-gradient(circle at 80% 0, rgba(255, 255, 255, 0.96), transparent 38%),
    linear-gradient(135deg, rgba(255, 253, 248, 0.98), rgba(251, 246, 237, 0.92)),
    var(--firm-surface);
  box-shadow: var(--firm-shadow-soft);
}

.firm-card-pad,
.firm-card > .elementor-widget-container {
  padding: var(--firm-card-pad);
}

.firm-card-strong {
  background: var(--firm-surface-strong);
  box-shadow: var(--firm-shadow);
}

.firm-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.firm-feature {
  display: grid;
  gap: 10px;
  min-height: 100%;
  padding: 18px;
  border: 1px solid rgba(91, 72, 48, 0.14);
  border-radius: var(--firm-radius);
  background: var(--firm-surface-strong);
  box-shadow: var(--firm-shadow-soft);
}

.firm-feature-title {
  margin: 0;
  color: var(--firm-text);
  font-size: 1rem;
  font-weight: 850;
  line-height: 1.3;
}

.firm-feature p {
  margin: 0;
  color: var(--firm-muted);
  font-size: 0.92rem;
  font-weight: 650;
}

/* Buttons */
.elementor-button,
.wp-block-button__link,
button,
input[type="button"],
input[type="submit"],
.firm-button {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--firm-button-height);
  min-width: 0;
  padding: 9px 13px;
  border: 1px solid rgba(35, 40, 32, 0.12);
  border-radius: var(--firm-radius-control);
  background: var(--firm-surface-strong);
  color: var(--firm-text);
  cursor: pointer;
  font-family: var(--firm-font-sans);
  font-size: 0.88rem;
  font-weight: 850;
  line-height: 1.2;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
  transition: transform var(--firm-transition-fast), background var(--firm-transition), border-color var(--firm-transition), box-shadow var(--firm-transition), color var(--firm-transition);
}

.elementor-button:hover,
.wp-block-button__link:hover,
button:hover,
input[type="button"]:hover,
input[type="submit"]:hover,
.firm-button:hover,
.elementor-button:focus-visible,
.firm-button:focus-visible {
  border-color: rgba(18, 63, 42, 0.22);
  background: #f7efe2;
  color: var(--firm-text);
  outline: none;
}

.elementor-button:active,
.firm-button:active,
button:active {
  transform: translateY(1px);
}

.elementor-button.elementor-size-sm,
.firm-button-sm {
  min-height: 38px;
  padding: 8px 11px;
  font-size: 0.82rem;
}

.firm-button-primary,
.elementor-button.elementor-button-link,
.elementor-widget-button:not(.firm-button-subtle):not(.firm-button-clay) .elementor-button,
input[type="submit"] {
  border-color: var(--firm-primary-600);
  background: var(--firm-primary-600);
  color: #ffffff;
  box-shadow: var(--firm-shadow-control);
}

.firm-button-primary:hover,
.firm-button-primary:focus-visible,
.elementor-widget-button:not(.firm-button-subtle):not(.firm-button-clay) .elementor-button:hover,
input[type="submit"]:hover,
input[type="submit"]:focus-visible {
  border-color: var(--firm-primary-hover);
  background: var(--firm-primary-hover);
  color: #ffffff;
}

.firm-button-subtle .elementor-button,
.firm-button-subtle,
.firm-button-secondary {
  border-color: rgba(35, 40, 32, 0.12);
  background: var(--firm-surface);
  color: var(--firm-text);
  box-shadow: none;
}

.firm-button-clay .elementor-button,
.firm-button-clay {
  border-color: rgba(168, 100, 68, 0.28);
  background: #fff4e7;
  color: #7c3f24;
}

.firm-button-danger {
  border-color: rgba(239, 68, 68, 0.28);
  background: rgba(239, 68, 68, 0.08);
  color: var(--firm-danger-strong);
}

button:disabled,
input:disabled,
textarea:disabled,
select:disabled,
.firm-button[aria-disabled="true"] {
  background: #e3e0d8;
  border-color: rgba(35, 40, 32, 0.1);
  box-shadow: none;
  color: #777064;
  cursor: not-allowed;
  transform: none;
}

/* Forms */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
select,
textarea,
.elementor-field {
  width: 100%;
  min-height: var(--firm-control-height);
  padding: 0 14px;
  border: 1px solid var(--firm-border);
  border-radius: var(--firm-radius);
  background: var(--firm-surface-strong);
  color: var(--firm-text);
  font-family: var(--firm-font-sans);
  font-size: 0.98rem;
  font-weight: 700;
  outline: none;
  transition: border-color var(--firm-transition), box-shadow var(--firm-transition), background var(--firm-transition);
}

textarea,
.elementor-field-textual.elementor-size-md {
  min-height: 132px;
  padding-block: 12px;
  line-height: 1.45;
}

input::placeholder,
textarea::placeholder,
.elementor-field::placeholder {
  color: var(--firm-muted-2);
}

input:focus,
select:focus,
textarea:focus,
.elementor-field:focus {
  border-color: rgba(18, 63, 42, 0.3);
  box-shadow: 0 0 0 4px var(--firm-focus);
}

label,
.elementor-field-label {
  color: var(--firm-muted);
  font-family: var(--firm-font-sans);
  font-size: 0.84rem;
  font-weight: 850;
  line-height: 1.2;
}

.firm-form-card,
.elementor-form.firm-form-card {
  display: grid;
  gap: 12px;
  max-width: 430px;
  padding: 36px;
  border: 1px solid var(--firm-border);
  border-radius: var(--firm-radius);
  background:
    radial-gradient(circle at 80% 0, rgba(255, 255, 255, 0.96), transparent 38%),
    linear-gradient(135deg, rgba(255, 253, 248, 0.98), rgba(251, 246, 237, 0.92)),
    var(--firm-surface);
  box-shadow: var(--firm-shadow);
}

/* Header and navigation */
.site-header,
.elementor-location-header,
.firm-header {
  min-height: var(--firm-nav-height);
  border-bottom: 1px solid rgba(91, 72, 48, 0.16);
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.98), rgba(241, 230, 212, 0.92)),
    var(--firm-surface);
  box-shadow: var(--firm-shadow-soft);
}

.elementor-nav-menu--main .elementor-item,
.firm-nav a,
.firm-nav button {
  border-radius: var(--firm-radius);
  color: var(--firm-text);
  font-family: var(--firm-font-sans);
  font-size: 0.92rem;
  font-weight: 800;
  line-height: 1.2;
}

.elementor-nav-menu--main .elementor-item:hover,
.elementor-nav-menu--main .elementor-item.elementor-item-active,
.firm-nav a:hover,
.firm-nav a:focus,
.firm-nav .current-menu-item > a {
  background: rgba(33, 71, 52, 0.08);
  color: var(--firm-primary);
}

/* Tables and data blocks */
table,
.firm-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  border: 1px solid var(--firm-border);
  border-radius: var(--firm-radius);
  background: var(--firm-surface-strong);
  box-shadow: var(--firm-shadow-soft);
}

th,
td {
  padding: 12px 14px;
  border-bottom: 1px solid rgba(91, 72, 48, 0.12);
  color: var(--firm-text);
  font-size: 0.92rem;
  line-height: 1.35;
  vertical-align: middle;
}

th {
  background: var(--firm-surface);
  color: var(--firm-muted);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

tr:last-child td {
  border-bottom: 0;
}

/* Badges, chips, and status labels */
.firm-badge,
.firm-chip,
.firm-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 5px 9px;
  border: 1px solid var(--firm-border);
  border-radius: var(--firm-radius-pill);
  background: var(--firm-surface);
  color: var(--firm-text);
  font-family: var(--firm-font-sans);
  font-size: 0.78rem;
  font-weight: 850;
  line-height: 1.2;
}

.firm-badge-accent {
  border-color: rgba(200, 154, 60, 0.34);
  background: rgba(200, 154, 60, 0.12);
  color: #6f4b21;
}

.firm-badge-clay,
.firm-badge-special {
  border-color: rgba(168, 100, 68, 0.32);
  background: #fff4e7;
  color: #7c3f24;
}

.firm-badge-success {
  border-color: rgba(33, 71, 52, 0.22);
  background: rgba(33, 71, 52, 0.08);
  color: var(--firm-primary);
}

.firm-badge-danger {
  border-color: rgba(239, 68, 68, 0.28);
  background: rgba(239, 68, 68, 0.08);
  color: var(--firm-danger-strong);
}

.firm-retailer-coles {
  background: var(--firm-coles-bg);
  color: var(--firm-coles);
}

.firm-retailer-woolworths {
  background: var(--firm-woolworths-bg);
  color: var(--firm-woolworths);
}

.firm-retailer-aldi {
  background: var(--firm-aldi-bg);
  color: var(--firm-aldi);
}

.firm-retailer-iga {
  background: var(--firm-iga-bg);
  color: var(--firm-iga);
}

.firm-retailer-amazon {
  background: var(--firm-amazon-bg);
  color: var(--firm-amazon);
}

/* Product and content cards */
.firm-product-card {
  display: grid;
  overflow: hidden;
  border: 1px solid rgba(91, 72, 48, 0.14);
  border-radius: var(--firm-radius);
  background: var(--firm-surface-strong);
  box-shadow: var(--firm-shadow-soft);
  transition: transform var(--firm-transition), border-color var(--firm-transition), box-shadow var(--firm-transition);
}

.firm-product-card:hover {
  transform: translateY(-1px);
  border-color: rgba(18, 63, 42, 0.22);
  box-shadow: var(--firm-shadow);
}

.firm-product-image {
  display: grid;
  place-items: center;
  aspect-ratio: 1 / 1;
  padding: 18px;
  background: #ffffff;
}

.firm-product-card-body {
  display: grid;
  gap: 8px;
  padding: 14px;
}

.firm-product-title {
  margin: 0;
  color: var(--firm-text);
  font-family: var(--firm-font-sans);
  font-size: 1rem;
  font-weight: 850;
  line-height: 1.28;
}

.firm-product-meta {
  color: #8c6742;
  font-size: 0.78rem;
  font-weight: 850;
  line-height: 1.2;
  text-transform: uppercase;
}

.firm-price {
  color: var(--firm-primary-600);
  font-family: var(--firm-font-display);
  font-size: clamp(1.8rem, 4vw, 2.45rem);
  font-weight: 500;
  line-height: 0.96;
}

/* Alerts */
.firm-alert {
  padding: 10px 12px;
  border-radius: var(--firm-radius);
  font-size: 0.92rem;
  font-weight: 750;
  line-height: 1.35;
}

.firm-alert-success {
  border: 1px solid rgba(33, 71, 52, 0.22);
  background: rgba(33, 71, 52, 0.08);
  color: var(--firm-primary);
}

.firm-alert-error {
  border: 1px solid rgba(239, 68, 68, 0.28);
  background: rgba(239, 68, 68, 0.08);
  color: var(--firm-danger-strong);
}

.firm-alert-warning {
  border: 1px solid rgba(183, 121, 31, 0.26);
  background: rgba(183, 121, 31, 0.12);
  color: #7c3f24;
}

/* WordPress blocks */
.wp-block-quote {
  margin: 24px 0;
  padding: 18px 20px;
  border-left: 4px solid var(--firm-accent);
  border-radius: var(--firm-radius);
  background: var(--firm-surface);
  color: var(--firm-text-soft);
}

.wp-block-separator {
  border: 0;
  border-top: 1px solid var(--firm-border);
}

code,
pre {
  font-family: var(--firm-font-mono);
}

pre {
  overflow: auto;
  padding: 16px;
  border-radius: var(--firm-radius-admin);
  background: #0f172a;
  color: #f8fafc;
  font-size: 0.86rem;
  line-height: 1.45;
}

/* Admin-style section option for Elementor pages that need dashboard/reporting UI */
.firm-admin-theme {
  --firm-bg: var(--firm-admin-bg);
  --firm-surface: var(--firm-admin-card);
  --firm-surface-strong: var(--firm-admin-card);
  --firm-text: var(--firm-admin-text);
  --firm-muted: var(--firm-admin-muted);
  --firm-muted-2: var(--firm-admin-muted-2);
  --firm-border: var(--firm-admin-border);
  --firm-primary: var(--firm-admin-primary);
  --firm-primary-600: var(--firm-admin-primary-700);
  --firm-focus: rgba(147, 197, 253, 0.25);
  background: var(--firm-admin-bg);
  color: var(--firm-admin-text);
}

/* Elementor spacing helpers */
.firm-gap-sm {
  gap: 10px;
}

.firm-gap-md {
  gap: 16px;
}

.firm-gap-lg {
  gap: 26px;
}

.firm-no-margin,
.firm-no-margin .elementor-heading-title,
.firm-no-margin p {
  margin: 0;
}

@media (max-width: 980px) {
  .firm-feature-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .firm-hero-content,
  .firm-brand-panel {
    min-height: auto;
    padding: 34px 24px;
  }
}

@media (max-width: 560px) {
  :root {
    --firm-page-pad-x: 14px;
    --firm-card-pad: 22px;
  }

  body,
  .elementor-kit {
    font-size: 15px;
  }

  h1,
  .firm-h1 {
    font-size: clamp(2.4rem, 13vw, 3rem);
  }

  h2,
  .firm-h2 {
    font-size: clamp(1.9rem, 10vw, 2.35rem);
  }

  .firm-feature-grid {
    grid-template-columns: 1fr;
  }

  .firm-form-card,
  .elementor-form.firm-form-card {
    padding: 26px 20px;
  }

  .elementor-button,
  .wp-block-button__link,
  .firm-button {
    width: 100%;
    white-space: normal;
  }

  th,
  td {
    padding: 10px;
  }
}/* End custom CSS */