/*
Theme Name: Leadflow Premium
Theme URI: https://lokal-seite.de
Author: Leadflow
Description: Premium lead landing page theme rendered from structured Leadflow payloads.
Version: 0.7.2
Requires at least: 6.0
Text Domain: leadflow-premium
*/

:root {
  --lf-paper: #f2eadf;
  --lf-paper-2: #fffaf2;
  --lf-ink: #120c08;
  --lf-brown: #2a160d;
  --lf-brown-2: #4b2916;
  --lf-caramel: #c98733;
  --lf-caramel-2: #e5bd77;
  --lf-muted: #806c5b;
  --lf-line: rgba(18, 12, 8, .13);
  --lf-white: rgba(255, 250, 242, .86);
  --lf-radius: 30px;
  --lf-max: 1420px;
  --lf-shadow: 0 34px 90px rgba(57, 32, 15, .18);
  --lf-shadow-soft: 0 18px 50px rgba(57, 32, 15, .10);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--lf-ink);
  background:
    radial-gradient(circle at 74% 5%, rgba(222, 169, 91, .30), transparent 34rem),
    radial-gradient(circle at 10% 44%, rgba(255,255,255,.76), transparent 36rem),
    linear-gradient(180deg, #fff8ee 0%, var(--lf-paper) 52%, #e9ddce 100%);
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
body.leadflow-premium-body { background: #f2eadf; }
a { color: inherit; }
.lf-page { min-height: 100vh; overflow-x: clip; }
.lf-shell { width: min(var(--lf-max), calc(100vw - 52px)); margin-inline: auto; }

.lf-topbar {
  position: sticky; top: 0; z-index: 50;
  border-bottom: 1px solid var(--lf-line);
  background: rgba(255, 250, 242, .82);
  backdrop-filter: blur(20px);
}
.admin-bar .lf-topbar { top: 32px; }
.lf-nav {
  min-height: 84px;
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto minmax(220px, 1fr);
  gap: 28px;
  align-items: center;
}
.lf-brand { text-decoration: none; display: inline-flex; flex-direction: column; line-height: 1.05; width: fit-content; }
.lf-brand-name { font-size: clamp(1.1rem, 1.4vw, 1.45rem); font-weight: 850; letter-spacing: -.045em; text-decoration: underline; text-underline-offset: 5px; }
.lf-brand-sub { margin-top: 7px; color: var(--lf-muted); font-size: .92rem; text-decoration: underline; text-underline-offset: 4px; }
.lf-menu { display: flex; gap: 28px; align-items: center; font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, sans-serif; font-size: .86rem; font-weight: 850; }
.lf-menu a { text-decoration: none; opacity: .78; transition: opacity .18s ease, transform .18s ease; }
.lf-menu a:hover { opacity: 1; transform: translateY(-1px); }
.lf-nav-cta { justify-self: end; }

.lf-btn {
  min-height: 54px; display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px; padding: 0 28px; border: 1px solid var(--lf-line);
  text-decoration: none; font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, sans-serif;
  font-weight: 950; letter-spacing: -.035em; font-size: .95rem; white-space: nowrap;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.lf-btn:hover { transform: translateY(-2px); }
.lf-btn-primary { background: var(--lf-ink); color: #fff8ee !important; box-shadow: 0 18px 42px rgba(18,12,8,.24); }
.lf-btn-secondary { background: rgba(255,250,242,.72); color: var(--lf-ink); }
.lf-btn-gold { background: var(--lf-caramel); color: #fff8ee !important; border-color: transparent; }

.lf-hero { position: relative; padding: clamp(58px, 7vw, 118px) 0 clamp(52px, 7vw, 100px); }
.lf-hero::before {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 52%; pointer-events: none;
  background-image: linear-gradient(90deg, rgba(18,12,8,.045) 1px, transparent 1px), linear-gradient(180deg, rgba(18,12,8,.035) 1px, transparent 1px);
  background-size: 72px 72px; mask-image: linear-gradient(180deg, #000, transparent);
}
.lf-hero-layout { position: relative; display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(420px, .92fr); gap: clamp(34px, 6vw, 86px); align-items: stretch; }
.lf-hero-copy { min-height: 520px; display: flex; flex-direction: column; justify-content: center; }
.lf-kicker { display: inline-flex; width: fit-content; max-width: 100%; align-items: center; gap: 10px; padding: 11px 16px 11px 12px; border-radius: 999px; background: rgba(255,250,242,.82); box-shadow: 0 20px 55px rgba(57,32,15,.11); color: #8d551a; font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, sans-serif; font-size: .86rem; font-weight: 900; margin-bottom: 30px; }
.lf-kicker-dot { width: 16px; height: 16px; border-radius: 999px; background: var(--lf-caramel); box-shadow: 0 0 0 7px rgba(201,135,51,.16); flex: 0 0 auto; }
.lf-hero h1 {
  margin: 0;
  max-width: 780px;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  font-size: clamp(2.9rem, 4.6vw, 5.8rem);
  line-height: .96;
  letter-spacing: -.065em;
  font-weight: 760;
}
.lf-hero-sub { max-width: 720px; margin: 32px 0 0; color: var(--lf-muted); font-size: clamp(1.22rem, 1.55vw, 1.64rem); line-height: 1.55; letter-spacing: -.028em; }
.lf-actions { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; margin-top: 34px; }

.lf-hero-panel {
  position: relative; min-height: 520px; border-radius: 42px; overflow: hidden; color: #fffaf2;
  background:
    linear-gradient(180deg, rgba(18,12,8,.08), rgba(18,12,8,.72)),
    radial-gradient(circle at 76% 16%, rgba(229,189,119,.70), transparent 13rem),
    linear-gradient(145deg, #6f421d 0%, #2a160d 62%, #120c08 100%);
  box-shadow: var(--lf-shadow);
  isolation: isolate;
}
.lf-hero-panel::before { content: ""; position: absolute; inset: 24px; border: 1px solid rgba(255,250,242,.18); border-radius: 30px; z-index: -1; }
.lf-hero-panel::after { content: "GS"; position: absolute; right: -22px; bottom: -68px; color: rgba(255,250,242,.07); font-size: clamp(12rem, 23vw, 23rem); line-height: .75; letter-spacing: -.13em; font-weight: 900; z-index: -1; }
.lf-panel-content { height: 100%; min-height: 520px; padding: clamp(30px, 4vw, 54px); display: flex; flex-direction: column; justify-content: space-between; }
.lf-panel-top { display: flex; justify-content: space-between; gap: 18px; align-items: flex-start; }
.lf-panel-badge { padding: 10px 14px; border-radius: 999px; background: rgba(255,250,242,.12); color: rgba(255,250,242,.88); font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, sans-serif; font-size: .84rem; font-weight: 800; }
.lf-rating-card { min-width: 160px; border-radius: 24px; background: rgba(255,250,242,.92); color: var(--lf-ink); padding: 22px; box-shadow: 0 24px 58px rgba(0,0,0,.18); }
.lf-rating-card strong { display: block; font-size: 3rem; line-height: .9; letter-spacing: -.06em; }
.lf-rating-card span { display: block; margin-top: 12px; color: var(--lf-muted); font-size: .88rem; }
.lf-panel-title { max-width: 440px; font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif; font-size: clamp(2.4rem, 3.7vw, 4.4rem); line-height: .88; letter-spacing: -.075em; }
.lf-panel-meta { display: grid; gap: 10px; }
.lf-meta-row { display: flex; align-items: center; gap: 10px; padding: 14px 16px; border-radius: 18px; background: rgba(255,250,242,.12); color: rgba(255,250,242,.91); backdrop-filter: blur(10px); }
.lf-meta-dot { width: 9px; height: 9px; border-radius: 999px; background: var(--lf-caramel-2); flex: 0 0 auto; }

.lf-trust { margin-top: -20px; position: relative; z-index: 2; }
.lf-trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.lf-stat { min-height: 118px; border-radius: 24px; padding: 24px; background: rgba(255,250,242,.82); border: 1px solid var(--lf-line); box-shadow: var(--lf-shadow-soft); }
.lf-stat strong { display: block; font-size: 1.75rem; line-height: 1; letter-spacing: -.055em; }
.lf-stat span { display: block; margin-top: 10px; color: var(--lf-muted); font-size: .95rem; }

.lf-section { padding: clamp(72px, 8vw, 126px) 0; }
.lf-section-head { display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, .46fr); gap: 50px; align-items: end; margin-bottom: 48px; }
.lf-section h2 {
  margin: 0;
  max-width: 820px;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  font-size: clamp(2.15rem, 3.4vw, 4.2rem);
  line-height: .98;
  letter-spacing: -.058em;
  font-weight: 760;
}
.lf-section-lede { color: var(--lf-muted); font-size: clamp(1.04rem, 1.22vw, 1.28rem); line-height: 1.62; }

.lf-service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.lf-service { position: relative; min-height: 230px; padding: 34px; border-radius: 28px; background: rgba(255,250,242,.86); border: 1px solid var(--lf-line); box-shadow: var(--lf-shadow-soft); overflow: hidden; transition: transform .2s ease, box-shadow .2s ease; }
.lf-service:hover { transform: translateY(-6px); box-shadow: var(--lf-shadow); }
.lf-service::before { content: ""; position: absolute; right: -70px; top: -70px; width: 170px; height: 170px; border-radius: 999px; background: rgba(201,135,51,.12); }
.lf-service-number { width: 44px; height: 44px; border-radius: 14px; display: grid; place-items: center; background: var(--lf-ink); color: #fffaf2; font-family: ui-sans-serif, system-ui, sans-serif; font-weight: 950; }
.lf-service h3 { margin: 36px 0 14px; font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif; font-size: clamp(1.45rem, 1.8vw, 2rem); line-height: 1.05; letter-spacing: -.05em; }
.lf-service p { margin: 0; color: var(--lf-muted); font-size: 1.06rem; line-height: 1.58; }

.lf-feature { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 24px; align-items: stretch; }
.lf-feature-card { border-radius: 36px; padding: clamp(32px, 4vw, 52px); background: linear-gradient(145deg, var(--lf-ink), var(--lf-brown)); color: #fffaf2; box-shadow: var(--lf-shadow); min-height: 520px; }
.lf-feature-card h2 { color: #fffaf2; }
.lf-feature-card p { max-width: 620px; color: rgba(255,250,242,.74); font-size: 1.2rem; line-height: 1.6; }
.lf-points { margin-top: 34px; display: grid; gap: 12px; }
.lf-point { display: flex; gap: 12px; align-items: flex-start; padding: 16px 18px; border-radius: 18px; background: rgba(255,250,242,.10); color: rgba(255,250,242,.90); }
.lf-point::before { content: ""; width: 9px; height: 9px; margin-top: 8px; border-radius: 99px; background: var(--lf-caramel-2); flex: 0 0 auto; }
.lf-editorial-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.lf-editorial-tile { min-height: 250px; border-radius: 30px; position: relative; overflow: hidden; padding: 26px; display: flex; align-items: end; background: radial-gradient(circle at 65% 22%, rgba(255,250,242,.44), transparent 8rem), linear-gradient(135deg, #d8ad70, #593019); box-shadow: var(--lf-shadow-soft); color: #fffaf2; }
.lf-editorial-tile:nth-child(2), .lf-editorial-tile:nth-child(4) { background: radial-gradient(circle at 70% 22%, rgba(255,250,242,.32), transparent 8rem), linear-gradient(135deg, #63351c, #160d08); }
.lf-editorial-tile strong { font-size: 1.35rem; letter-spacing: -.045em; }

.lf-contact-grid { display: grid; grid-template-columns: .95fr 1.05fr; gap: 24px; }
.lf-contact-card { border-radius: 36px; padding: clamp(34px, 4.4vw, 60px); background: rgba(255,250,242,.88); border: 1px solid var(--lf-line); box-shadow: var(--lf-shadow-soft); }
.lf-contact-card h2 { font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif; font-size: clamp(2.1rem, 3.1vw, 3.8rem); line-height: .9; letter-spacing: -.075em; }
.lf-contact-card p { color: var(--lf-muted); font-size: 1.14rem; line-height: 1.62; }
.lf-info-list { display: grid; gap: 12px; margin-top: 28px; }
.lf-info-row { display: block; padding: 17px 18px; border-radius: 18px; background: rgba(18,12,8,.045); text-decoration: none; }

.lf-footer { border-top: 1px solid var(--lf-line); padding: 48px 0 66px; }
.lf-footer-grid { display: grid; grid-template-columns: 1fr auto; gap: 24px; color: var(--lf-muted); }
.lf-footer strong { display: block; color: var(--lf-ink); font-size: 1.35rem; letter-spacing: -.045em; }
.lf-footer span { display: block; margin-top: 6px; }
.lf-mobile-sticky { display: none; }

@media (max-width: 1120px) {
  .lf-nav { grid-template-columns: 1fr auto; }
  .lf-menu { display: none; }
  .lf-hero-layout, .lf-section-head, .lf-feature, .lf-contact-grid { grid-template-columns: 1fr; }
  .lf-hero-copy, .lf-hero-panel, .lf-panel-content { min-height: auto; }
  .lf-hero-panel { min-height: 520px; }
  .lf-panel-content { min-height: 520px; }
  .lf-trust-grid, .lf-service-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .lf-shell { width: min(100% - 28px, var(--lf-max)); }
  .lf-nav { min-height: 74px; }
  .lf-nav-cta { display: none; }
  .lf-hero { padding-top: 44px; }
  .lf-hero h1 { font-size: clamp(3.45rem, 16vw, 5.25rem); line-height: .86; }
  .lf-hero-sub { font-size: 1.12rem; }
  .lf-actions .lf-btn { width: 100%; }
  .lf-hero-panel, .lf-panel-content { min-height: 430px; }
  .lf-panel-content { padding: 26px; }
  .lf-panel-top { display: grid; gap: 14px; }
  .lf-rating-card { width: fit-content; }
  .lf-panel-title { font-size: 3.1rem; }
  .lf-trust { margin-top: 0; }
  .lf-trust-grid, .lf-service-grid, .lf-editorial-grid { grid-template-columns: 1fr; }
  .lf-service { min-height: 245px; }
  .lf-service h3 { margin-top: 52px; }
  .lf-section h2, .lf-contact-card h2 { font-size: clamp(2.65rem, 13vw, 4.4rem); }
  .lf-footer-grid { grid-template-columns: 1fr; }
  .lf-mobile-sticky { position: fixed; z-index: 70; left: 12px; right: 12px; bottom: 12px; display: block; }
  .lf-mobile-sticky .lf-btn { width: 100%; min-height: 58px; }
}


/* Leadflow controlled design tokens */
.lf-page.lf-headline-compact .lf-hero h1 {
  max-width: 780px;
  font-size: clamp(3rem, 5.2vw, 6.4rem);
  line-height: .92;
  letter-spacing: -.072em;
}

.lf-page.lf-headline-balanced .lf-hero h1 {
  max-width: 860px;
  font-size: clamp(3.25rem, 5.8vw, 7.2rem);
  line-height: .90;
}

.lf-page.lf-headline-large .lf-hero h1 {
  max-width: 940px;
  font-size: clamp(3.7rem, 6.4vw, 8.2rem);
  line-height: .87;
}

.lf-page.lf-density-compact .lf-section {
  padding: clamp(54px, 6vw, 88px) 0;
}

.lf-page.lf-density-compact .lf-service {
  min-height: 225px;
}

.lf-page.lf-density-compact .lf-service h3 {
  margin-top: 38px;
}

.lf-page.lf-palette-soft_neutral {
  --lf-paper: #f4eee6;
  --lf-paper-2: #fffaf3;
  --lf-ink: #17120e;
  --lf-brown: #35271e;
  --lf-brown-2: #5e4534;
  --lf-caramel: #b9844d;
  --lf-caramel-2: #e0bf8e;
  --lf-muted: #79695b;
}

.lf-page.lf-palette-deep_brown {
  --lf-paper: #eee5d7;
  --lf-paper-2: #fff8ec;
  --lf-ink: #120b07;
  --lf-brown: #1c100a;
  --lf-brown-2: #3d2114;
  --lf-caramel: #c3843e;
  --lf-caramel-2: #e6bd79;
}

.lf-page.lf-hero-contact_first .lf-hero-layout {
  grid-template-columns: minmax(0, .95fr) minmax(430px, 1.05fr);
}

.lf-page.lf-card-minimal .lf-service,
.lf-page.lf-card-minimal .lf-stat,
.lf-page.lf-card-minimal .lf-contact-card {
  box-shadow: none;
  background: rgba(255,250,242,.72);
}

@media (max-width: 760px) {
  .lf-page.lf-headline-compact .lf-hero h1,
  .lf-page.lf-headline-balanced .lf-hero h1,
  .lf-page.lf-headline-large .lf-hero h1 {
    font-size: clamp(2.9rem, 12vw, 4.5rem);
    line-height: .92;
  }
}


/* v0.2.2: stronger controlled premium defaults */
.lf-brand-name,
.lf-stat strong,
.lf-feature-card h2,
.lf-proof-card h3 {
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
}

.lf-page.lf-headline-compact .lf-hero h1 {
  max-width: 740px;
  font-size: clamp(2.75rem, 4.2vw, 5.25rem);
  line-height: .98;
  letter-spacing: -.06em;
}

.lf-page.lf-headline-balanced .lf-hero h1 {
  max-width: 800px;
  font-size: clamp(2.95rem, 4.8vw, 6rem);
  line-height: .96;
}

.lf-page.lf-headline-large .lf-hero h1 {
  max-width: 860px;
  font-size: clamp(3.2rem, 5.3vw, 6.6rem);
  line-height: .94;
}

.lf-proof-card {
  border-radius: 36px;
  padding: clamp(32px, 4vw, 56px);
  min-height: 520px;
  background:
    radial-gradient(circle at 78% 18%, rgba(229,189,119,.38), transparent 13rem),
    linear-gradient(145deg, rgba(255,250,242,.94), rgba(255,250,242,.72));
  border: 1px solid var(--lf-line);
  box-shadow: var(--lf-shadow-soft);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.lf-proof-eyebrow {
  display: inline-flex;
  width: fit-content;
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(18,12,8,.06);
  color: var(--lf-muted);
  font-size: .78rem;
  font-weight: 850;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.lf-proof-card h3 {
  margin: 24px 0 14px;
  font-size: clamp(2.2rem, 3.5vw, 4.4rem);
  line-height: .95;
  letter-spacing: -.065em;
}

.lf-proof-card p {
  max-width: 620px;
  color: var(--lf-muted);
  font-size: 1.08rem;
  line-height: 1.62;
}

.lf-proof-list {
  display: grid;
  gap: 12px;
  margin-top: 28px;
}

.lf-proof-row {
  padding: 15px 17px;
  border-radius: 18px;
  background: rgba(18,12,8,.045);
  color: var(--lf-ink);
}

.lf-page.lf-density-compact .lf-section {
  padding: clamp(50px, 5.8vw, 82px) 0;
}

@media (max-width: 760px) {
  .lf-page.lf-headline-compact .lf-hero h1,
  .lf-page.lf-headline-balanced .lf-hero h1,
  .lf-page.lf-headline-large .lf-hero h1 {
    font-size: clamp(2.55rem, 10.5vw, 4rem);
    line-height: .98;
  }

  .lf-proof-card {
    min-height: auto;
  }

  .lf-proof-card h3 {
    font-size: clamp(2.1rem, 10vw, 3.5rem);
  }
}


/* =========================================================
   Leadflow Premium v0.3.0
   Premium local-business design system
   ========================================================= */

:root {
  --lf-accent: #d2933f;
  --lf-accent-2: #f0c978;
  --lf-accent-dark: #8f5521;
  --lf-cream: #fff9ef;
  --lf-surface: rgba(255, 250, 242, .90);
  --lf-surface-strong: #fffaf2;
  --lf-border-soft: rgba(30, 20, 12, .10);
}

body.leadflow-premium-body {
  background:
    radial-gradient(circle at 82% 8%, rgba(240, 201, 120, .28), transparent 28rem),
    radial-gradient(circle at 10% 20%, rgba(255,255,255,.78), transparent 32rem),
    linear-gradient(180deg, #fff8ed 0%, #f0e5d7 58%, #e8dcca 100%);
}

.lf-shell {
  width: min(1320px, calc(100vw - 48px));
}

.lf-topbar {
  background: rgba(255, 249, 239, .88);
}

.lf-nav {
  min-height: 76px;
}

.lf-brand-name {
  font-size: clamp(1.05rem, 1.1vw, 1.25rem);
}

.lf-brand-sub {
  font-size: .82rem;
}

.lf-btn {
  min-height: 50px;
  padding: 0 24px;
  border-radius: 999px;
  font-size: .91rem;
}

.lf-btn-primary {
  background: linear-gradient(135deg, #1b1009 0%, #3b2213 52%, #9a5e28 100%);
  color: #fff8ed !important;
  border-color: rgba(255,255,255,.06);
  box-shadow: 0 18px 44px rgba(79, 42, 16, .25);
}

.lf-btn-primary:hover {
  box-shadow: 0 22px 54px rgba(79, 42, 16, .32);
}

.lf-btn-secondary {
  background: rgba(255, 250, 242, .86);
  border-color: rgba(30, 20, 12, .13);
}

.lf-hero {
  padding: clamp(48px, 5.4vw, 86px) 0 clamp(36px, 4.8vw, 72px);
}

.lf-hero-layout {
  grid-template-columns: minmax(0, .98fr) minmax(390px, .88fr);
  gap: clamp(28px, 4.8vw, 64px);
  align-items: center;
}

.lf-hero-copy {
  min-height: 500px;
}

.lf-kicker {
  margin-bottom: 24px;
  font-size: .78rem;
  padding: 10px 14px 10px 11px;
  box-shadow: 0 16px 40px rgba(57,32,15,.10);
}

.lf-hero h1 {
  max-width: 760px;
  font-size: clamp(2.85rem, 4.6vw, 5.7rem);
  line-height: .96;
  letter-spacing: -.065em;
}

.lf-page.lf-headline-compact .lf-hero h1,
.lf-page.lf-headline-balanced .lf-hero h1,
.lf-page.lf-headline-large .lf-hero h1 {
  max-width: 760px;
  font-size: clamp(2.85rem, 4.6vw, 5.7rem);
  line-height: .96;
  letter-spacing: -.065em;
}

.lf-hero-sub {
  max-width: 620px;
  margin-top: 24px;
  font-size: clamp(1.05rem, 1.22vw, 1.34rem);
  line-height: 1.6;
}

.lf-actions {
  margin-top: 28px;
}

.lf-hero-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
  max-width: 720px;
}

.lf-mini-badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 10px 13px;
  border-radius: 999px;
  background: rgba(255, 250, 242, .84);
  border: 1px solid rgba(30, 20, 12, .10);
  color: var(--lf-muted);
  font-size: .84rem;
  font-weight: 700;
  box-shadow: 0 12px 30px rgba(57,32,15,.07);
}

.lf-icon-badge {
  width: 34px;
  height: 34px;
  display: inline-grid;
  place-items: center;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--lf-accent), var(--lf-accent-dark));
  color: #fff8ed;
  flex: 0 0 auto;
}

.lf-icon-badge svg {
  width: 18px;
  height: 18px;
  display: block;
}

.lf-hero-panel {
  min-height: 500px;
  border-radius: 36px;
  background:
    radial-gradient(circle at 74% 16%, rgba(240,201,120,.74), transparent 10rem),
    linear-gradient(145deg, #74441e 0%, #29150b 62%, #120c08 100%);
}

.lf-panel-content {
  min-height: 500px;
  padding: clamp(26px, 3.4vw, 44px);
}

.lf-panel-title {
  max-width: 430px;
  font-size: clamp(2.25rem, 3.4vw, 4.25rem);
  line-height: .94;
}

.lf-rating-card {
  min-width: 142px;
  padding: 19px;
}

.lf-rating-card strong {
  font-size: 2.65rem;
}

.lf-meta-row {
  min-height: 46px;
  padding: 12px 14px;
  font-size: .92rem;
  color: rgba(255,250,242,.94);
}

.lf-trust {
  margin-top: 0;
}

.lf-trust-grid {
  gap: 14px;
}

.lf-stat {
  min-height: 98px;
  padding: 20px;
  border-radius: 22px;
  background: rgba(255, 250, 242, .84);
}

.lf-stat strong {
  font-size: 1.55rem;
}

.lf-stat span {
  font-size: .88rem;
}

.lf-section,
.lf-page.lf-density-compact .lf-section,
.lf-page.lf-density-balanced .lf-section,
.lf-page.lf-density-airy .lf-section {
  padding: clamp(46px, 5.2vw, 78px) 0;
}

.lf-section-head {
  margin-bottom: 32px;
  gap: 36px;
}

.lf-section h2,
.lf-page.lf-headline-compact .lf-section h2 {
  max-width: 760px;
  font-size: clamp(2.1rem, 3.25vw, 4.1rem);
  line-height: 1;
  letter-spacing: -.058em;
}

.lf-section-lede {
  font-size: clamp(.98rem, 1.08vw, 1.15rem);
  line-height: 1.65;
}

.lf-service-grid {
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.lf-service {
  min-height: 230px;
  padding: 26px;
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,250,242,.96), rgba(255,250,242,.80));
  border: 1px solid var(--lf-border-soft);
}

.lf-service::before {
  width: 120px;
  height: 120px;
  right: -52px;
  top: -52px;
  background: rgba(210,147,63,.12);
}

.lf-service-number {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--lf-accent), var(--lf-accent-dark));
  color: #fff8ed;
}

.lf-service h3 {
  margin: 34px 0 12px;
  font-size: clamp(1.2rem, 1.38vw, 1.55rem);
  line-height: 1.1;
}

.lf-service p {
  font-size: .98rem;
  line-height: 1.55;
}

.lf-feature {
  grid-template-columns: .88fr 1.12fr;
  gap: 20px;
}

.lf-feature-card,
.lf-proof-card {
  min-height: 430px;
  border-radius: 34px;
}

.lf-feature-card {
  padding: clamp(30px, 3.6vw, 48px);
}

.lf-feature-card h2 {
  font-size: clamp(2.1rem, 3.3vw, 4.1rem);
  line-height: 1;
}

.lf-feature-card p,
.lf-proof-card p {
  font-size: 1.02rem;
}

.lf-proof-card h3 {
  font-size: clamp(2.05rem, 3.2vw, 4rem);
  line-height: .98;
}

.lf-proof-row,
.lf-point,
.lf-info-row {
  font-size: .96rem;
}

.lf-contact-grid {
  gap: 20px;
}

.lf-contact-card {
  border-radius: 32px;
  padding: clamp(30px, 3.6vw, 48px);
}

.lf-contact-card h2 {
  font-size: clamp(2rem, 3.05vw, 3.7rem);
  line-height: 1;
}

.lf-contact-card p {
  font-size: 1.02rem;
}

@media (max-width: 1180px) {
  .lf-service-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 760px) {
  .lf-shell {
    width: min(100% - 24px, 1320px);
  }

  .lf-hero {
    padding-top: 28px;
  }

  .lf-hero-layout {
    display: flex;
    flex-direction: column;
    gap: 22px;
  }

  .lf-hero-copy {
    min-height: auto;
    order: 1;
  }

  .lf-hero-panel {
    order: 2;
    min-height: 390px;
    border-radius: 28px;
  }

  .lf-panel-content {
    min-height: 390px;
    padding: 22px;
  }

  .lf-panel-top {
    display: flex;
    justify-content: space-between;
  }

  .lf-rating-card {
    min-width: 124px;
    padding: 16px;
  }

  .lf-rating-card strong {
    font-size: 2.2rem;
  }

  .lf-panel-title {
    font-size: clamp(2.15rem, 10vw, 3.25rem);
    line-height: .98;
  }

  .lf-hero h1,
  .lf-page.lf-headline-compact .lf-hero h1,
  .lf-page.lf-headline-balanced .lf-hero h1,
  .lf-page.lf-headline-large .lf-hero h1 {
    font-size: clamp(2.42rem, 10.2vw, 3.8rem);
    line-height: .98;
  }

  .lf-hero-badges {
    gap: 8px;
  }

  .lf-mini-badge {
    font-size: .78rem;
    padding: 9px 11px;
  }

  .lf-trust-grid,
  .lf-service-grid {
    grid-template-columns: 1fr 1fr;
  }

  .lf-section-head {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .lf-section h2,
  .lf-page.lf-headline-compact .lf-section h2 {
    font-size: clamp(2rem, 9vw, 3.1rem);
  }

  .lf-feature,
  .lf-contact-grid {
    grid-template-columns: 1fr;
  }

  .lf-feature-card,
  .lf-proof-card {
    min-height: auto;
  }
}

@media (max-width: 520px) {
  .lf-trust-grid,
  .lf-service-grid {
    grid-template-columns: 1fr;
  }

  .lf-panel-top {
    display: grid;
  }

  .lf-nav {
    min-height: 70px;
  }

  .lf-brand-name {
    font-size: 1rem;
  }
}


/* =========================================================
   Leadflow Premium v0.3.1
   Final Phase-A polish: badges, spacing, mobile hero
   ========================================================= */

.lf-shell {
  width: min(1280px, calc(100vw - 48px));
}

.lf-hero {
  padding: clamp(42px, 4.8vw, 74px) 0 clamp(30px, 4vw, 58px);
}

.lf-hero-layout {
  grid-template-columns: minmax(0, .94fr) minmax(380px, .82fr);
  gap: clamp(26px, 4.2vw, 56px);
}

.lf-hero-copy {
  min-height: 460px;
}

.lf-hero h1,
.lf-page.lf-headline-compact .lf-hero h1,
.lf-page.lf-headline-balanced .lf-hero h1,
.lf-page.lf-headline-large .lf-hero h1 {
  max-width: 700px;
  font-size: clamp(2.65rem, 4.05vw, 5.05rem);
  line-height: .99;
  letter-spacing: -.058em;
}

.lf-hero-sub {
  max-width: 570px;
  margin-top: 22px;
  font-size: clamp(1rem, 1.1vw, 1.22rem);
  line-height: 1.62;
}

.lf-kicker {
  margin-bottom: 20px;
  font-size: .75rem;
}

.lf-hero-panel {
  min-height: 455px;
  border-radius: 34px;
}

.lf-panel-content {
  min-height: 455px;
  padding: clamp(24px, 3vw, 38px);
}

.lf-panel-title {
  max-width: 390px;
  font-size: clamp(2rem, 3.05vw, 3.75rem);
  line-height: .97;
}

.lf-panel-badge {
  font-size: .78rem;
  padding: 8px 12px;
}

.lf-rating-card {
  min-width: 128px;
  border-radius: 20px;
  padding: 17px;
}

.lf-rating-card strong {
  font-size: 2.35rem;
}

.lf-rating-card span {
  font-size: .78rem;
}

.lf-meta-row {
  min-height: 42px;
  padding: 11px 14px;
  border-radius: 15px;
  font-size: .88rem;
}

.lf-btn-primary {
  background: linear-gradient(135deg, #1a1009 0%, #603414 58%, #b8752d 100%);
}

.lf-btn-secondary {
  background: rgba(255, 250, 242, .92);
}

.lf-hero-badges {
  gap: 9px;
  margin-top: 22px;
  max-width: 640px;
}

.lf-mini-badge {
  min-height: 42px;
  padding: 7px 12px 7px 8px;
  border-radius: 999px;
  background: rgba(255, 250, 242, .92);
  border: 1px solid rgba(30, 20, 12, .11);
  color: #6f5d4e;
  font-size: .78rem;
  font-weight: 780;
  box-shadow: 0 10px 26px rgba(57,32,15,.06);
}

.lf-icon-badge {
  width: 30px;
  height: 30px;
  border-radius: 11px;
  background: linear-gradient(135deg, #c88939, #8f4e1e);
}

.lf-icon-badge svg {
  width: 16px;
  height: 16px;
}

.lf-trust-grid {
  gap: 12px;
}

.lf-stat {
  min-height: 86px;
  padding: 18px;
  border-radius: 20px;
}

.lf-stat strong {
  font-size: 1.42rem;
}

.lf-stat span {
  margin-top: 7px;
  font-size: .83rem;
}

.lf-section,
.lf-page.lf-density-compact .lf-section,
.lf-page.lf-density-balanced .lf-section,
.lf-page.lf-density-airy .lf-section {
  padding: clamp(38px, 4.4vw, 66px) 0;
}

.lf-section-head {
  margin-bottom: 28px;
  gap: 30px;
}

.lf-section h2,
.lf-page.lf-headline-compact .lf-section h2 {
  max-width: 710px;
  font-size: clamp(1.95rem, 2.85vw, 3.55rem);
  line-height: 1.03;
  letter-spacing: -.052em;
}

.lf-section-lede {
  max-width: 440px;
  font-size: .98rem;
  line-height: 1.62;
}

.lf-service-grid {
  gap: 14px;
}

.lf-service {
  min-height: 210px;
  padding: 24px;
  border-radius: 24px;
}

.lf-service h3 {
  margin-top: 28px;
  font-size: clamp(1.12rem, 1.25vw, 1.38rem);
}

.lf-service p {
  font-size: .92rem;
}

.lf-feature {
  gap: 18px;
}

.lf-feature-card,
.lf-proof-card {
  min-height: 390px;
  border-radius: 30px;
}

.lf-feature-card h2,
.lf-proof-card h3 {
  font-size: clamp(1.95rem, 2.9vw, 3.55rem);
  line-height: 1.02;
}

.lf-feature-card p,
.lf-proof-card p {
  font-size: .98rem;
  line-height: 1.58;
}

.lf-point,
.lf-proof-row {
  padding: 13px 15px;
  border-radius: 15px;
  font-size: .9rem;
}

.lf-contact-card {
  border-radius: 30px;
  padding: clamp(28px, 3.1vw, 42px);
}

.lf-contact-card h2 {
  font-size: clamp(1.9rem, 2.65vw, 3.35rem);
}

.lf-contact-card p {
  font-size: .98rem;
}

.lf-info-row {
  padding: 14px 16px;
  border-radius: 15px;
  font-size: .92rem;
}

.lf-footer {
  padding: 34px 0 48px;
}

@media (max-width: 900px) {
  .lf-hero-layout {
    grid-template-columns: 1fr;
  }

  .lf-hero-copy {
    min-height: auto;
  }

  .lf-hero-panel {
    min-height: 420px;
  }

  .lf-panel-content {
    min-height: 420px;
  }
}

@media (max-width: 760px) {
  .lf-shell {
    width: min(100% - 22px, 1280px);
  }

  .lf-topbar {
    position: relative;
  }

  .lf-nav {
    min-height: 66px;
  }

  .lf-hero {
    padding-top: 24px;
  }

  .lf-hero h1,
  .lf-page.lf-headline-compact .lf-hero h1,
  .lf-page.lf-headline-balanced .lf-hero h1,
  .lf-page.lf-headline-large .lf-hero h1 {
    max-width: 100%;
    font-size: clamp(2.15rem, 8.6vw, 3.25rem);
    line-height: 1.02;
    letter-spacing: -.052em;
  }

  .lf-hero-sub {
    margin-top: 18px;
    font-size: 1rem;
  }

  .lf-actions {
    margin-top: 22px;
  }

  .lf-actions .lf-btn {
    width: 100%;
    min-height: 52px;
  }

  .lf-hero-badges {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 18px;
  }

  .lf-mini-badge {
    width: 100%;
    min-height: 40px;
    justify-content: flex-start;
    font-size: .74rem;
  }

  .lf-icon-badge {
    width: 28px;
    height: 28px;
    border-radius: 10px;
  }

  .lf-hero-panel {
    min-height: 360px;
    border-radius: 26px;
  }

  .lf-panel-content {
    min-height: 360px;
    padding: 20px;
  }

  .lf-panel-title {
    font-size: clamp(1.9rem, 8.4vw, 2.85rem);
    line-height: 1;
  }

  .lf-panel-top {
    display: flex;
    align-items: flex-start;
  }

  .lf-rating-card {
    min-width: 112px;
    padding: 14px;
  }

  .lf-rating-card strong {
    font-size: 2rem;
  }

  .lf-meta-row {
    font-size: .8rem;
    padding: 10px 12px;
  }

  .lf-trust-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .lf-stat {
    min-height: 78px;
  }

  .lf-service-grid {
    grid-template-columns: 1fr;
  }

  .lf-section h2,
  .lf-page.lf-headline-compact .lf-section h2 {
    font-size: clamp(1.9rem, 8.4vw, 2.9rem);
  }

  .lf-feature-card h2,
  .lf-proof-card h3,
  .lf-contact-card h2 {
    font-size: clamp(1.85rem, 8vw, 2.75rem);
  }
}

@media (max-width: 430px) {
  .lf-hero-badges {
    grid-template-columns: 1fr;
  }

  .lf-trust-grid {
    grid-template-columns: 1fr;
  }

  .lf-panel-top {
    display: grid;
    gap: 12px;
  }

  .lf-rating-card {
    width: fit-content;
  }
}


/* =========================================================
   Leadflow Premium v0.4.0
   Conversion-first salon landing page
   ========================================================= */

.lfv4 {
  --v4-bg: #f5eadb;
  --v4-paper: #fffaf2;
  --v4-paper-2: #fff6e8;
  --v4-ink: #160d08;
  --v4-muted: #755f4f;
  --v4-line: rgba(37, 24, 14, .12);
  --v4-brown: #241208;
  --v4-brown-2: #603416;
  --v4-copper: #b7742b;
  --v4-gold: #e1ad5c;
  --v4-green: #44624a;
  --v4-shadow: 0 24px 70px rgba(61, 38, 18, .13);
  --v4-shadow-soft: 0 16px 45px rgba(61, 38, 18, .09);
  min-height: 100vh;
  color: var(--v4-ink);
  background:
    radial-gradient(circle at 80% 8%, rgba(225, 173, 92, .26), transparent 30rem),
    radial-gradient(circle at 14% 18%, rgba(255, 255, 255, .72), transparent 34rem),
    linear-gradient(180deg, #fff8ec 0%, var(--v4-bg) 58%, #e8dac7 100%);
}

.lfv4-shell {
  width: min(1240px, calc(100vw - 44px));
  margin-inline: auto;
}

.lfv4-topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 248, 236, .90);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--v4-line);
}

.lfv4-nav {
  min-height: 72px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
}

.lfv4-brand {
  display: inline-flex;
  flex-direction: column;
  color: var(--v4-ink);
  text-decoration: none;
  line-height: 1.05;
}

.lfv4-brand span {
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  font-size: 1.18rem;
  font-weight: 800;
  letter-spacing: -.04em;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.lfv4-brand small {
  margin-top: 6px;
  color: var(--v4-muted);
  font-size: .82rem;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.lfv4-menu {
  display: flex;
  align-items: center;
  gap: 24px;
  font-size: .83rem;
  font-weight: 850;
}

.lfv4-menu a {
  color: var(--v4-ink);
  text-decoration: none;
  opacity: .78;
}

.lfv4-menu a:hover {
  opacity: 1;
}

.lfv4-nav > .lfv4-btn {
  justify-self: end;
}

.lfv4-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 24px;
  border-radius: 999px;
  border: 1px solid var(--v4-line);
  text-decoration: none;
  font-size: .92rem;
  line-height: 1;
  font-weight: 900;
  color: var(--v4-ink);
  white-space: nowrap;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.lfv4-btn:hover {
  transform: translateY(-2px);
}

.lfv4-btn-primary {
  color: #fff8ed !important;
  background: linear-gradient(135deg, #1a0e07 0%, #6d3b18 62%, #bd7a2f 100%);
  border-color: rgba(255, 255, 255, .08);
  box-shadow: 0 18px 42px rgba(87, 46, 17, .24);
}

.lfv4-btn-secondary {
  background: rgba(255, 250, 242, .9);
  border-color: rgba(37, 24, 14, .13);
}

.lfv4-hero {
  padding: clamp(48px, 5vw, 86px) 0 clamp(34px, 4.2vw, 68px);
}

.lfv4-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(400px, .82fr);
  align-items: center;
  gap: clamp(32px, 5vw, 68px);
}

.lfv4-kicker {
  width: fit-content;
  max-width: 100%;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 10px 14px 10px 10px;
  border-radius: 999px;
  background: rgba(255, 250, 242, .86);
  color: #8b511d;
  border: 1px solid rgba(37, 24, 14, .08);
  box-shadow: 0 14px 42px rgba(61, 38, 18, .10);
  font-size: .78rem;
  font-weight: 860;
}

.lfv4-dot {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 5px solid rgba(225, 173, 92, .34);
  background: var(--v4-copper);
  flex: 0 0 auto;
}

.lfv4-hero h1 {
  margin: 26px 0 0;
  max-width: 740px;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  font-size: clamp(3rem, 4.8vw, 5.9rem);
  line-height: .98;
  letter-spacing: -.065em;
  font-weight: 800;
}

.lfv4-hero p {
  max-width: 640px;
  margin: 24px 0 0;
  color: var(--v4-muted);
  font-size: clamp(1.06rem, 1.18vw, 1.28rem);
  line-height: 1.62;
}

.lfv4-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

.lfv4-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
  max-width: 700px;
}

.lfv4-badge {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 7px 13px 7px 8px;
  border-radius: 999px;
  background: rgba(255, 250, 242, .91);
  border: 1px solid rgba(37, 24, 14, .10);
  box-shadow: 0 10px 25px rgba(61, 38, 18, .07);
  color: #6d5948;
  font-size: .8rem;
  font-weight: 780;
}

.lfv4 .lf-icon-badge {
  width: 30px;
  height: 30px;
  border-radius: 11px;
  background: linear-gradient(135deg, #c88635, #8d4f1f);
  color: #fff8ed;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18);
}

.lfv4 .lf-icon-badge svg {
  width: 16px;
  height: 16px;
}

.lfv4-hero-card {
  position: relative;
  min-height: 470px;
  border-radius: 36px;
  padding: 24px;
  background:
    radial-gradient(circle at 74% 18%, rgba(225,173,92,.70), transparent 10.5rem),
    linear-gradient(145deg, #75431d 0%, #2b160b 62%, #130b07 100%);
  box-shadow: var(--v4-shadow);
  overflow: hidden;
}

.lfv4-hero-card::after {
  content: "";
  position: absolute;
  right: -58px;
  bottom: -92px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  border: 44px solid rgba(255,255,255,.06);
}

.lfv4-hero-card-inner {
  position: relative;
  z-index: 2;
  min-height: 422px;
  height: 100%;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,.18);
  padding: clamp(22px, 3vw, 34px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.lfv4-hero-card-top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
}

.lfv4-pill,
.lfv4-eyebrow {
  display: inline-flex;
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 900;
  letter-spacing: .03em;
  text-transform: uppercase;
}

.lfv4-pill {
  color: #fff8ed;
  background: rgba(255,255,255,.13);
}

.lfv4-eyebrow {
  color: #85684f;
  background: rgba(37,24,14,.06);
}

.lfv4-rating-card {
  min-width: 128px;
  border-radius: 20px;
  padding: 17px;
  background: rgba(255, 250, 242, .96);
  color: var(--v4-ink);
  box-shadow: 0 18px 44px rgba(20, 10, 4, .18);
}

.lfv4-rating-card strong {
  display: block;
  font-size: 2.35rem;
  line-height: 1;
  letter-spacing: -.06em;
}

.lfv4-rating-card span {
  display: block;
  margin-top: 9px;
  color: var(--v4-muted);
  font-size: .78rem;
}

.lfv4-hero-card-title {
  max-width: 430px;
  color: #fff8ed;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  font-size: clamp(2.25rem, 3.4vw, 4.1rem);
  line-height: .97;
  letter-spacing: -.062em;
  font-weight: 800;
}

.lfv4-quick-list {
  display: grid;
  gap: 10px;
}

.lfv4-quick-row {
  min-height: 46px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 13px;
  border-radius: 15px;
  color: rgba(255, 250, 242, .95);
  background: rgba(255,255,255,.12);
  text-decoration: none;
  font-size: .88rem;
}

.lfv4-quick-row .lf-icon-badge {
  width: 24px;
  height: 24px;
  border-radius: 9px;
}

.lfv4-trust-strip {
  padding: 0 0 clamp(36px, 4vw, 60px);
}

.lfv4-trust-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.lfv4-stat {
  min-height: 92px;
  padding: 19px;
  border-radius: 22px;
  background: rgba(255,250,242,.82);
  border: 1px solid var(--v4-line);
  box-shadow: var(--v4-shadow-soft);
}

.lfv4-stat strong {
  display: block;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  font-size: 1.48rem;
  line-height: 1;
  letter-spacing: -.05em;
}

.lfv4-stat span {
  display: block;
  margin-top: 9px;
  color: var(--v4-muted);
  font-size: .84rem;
}

.lfv4-section {
  padding: clamp(48px, 5.6vw, 84px) 0;
}

.lfv4-section-soft {
  background: rgba(255,255,255,.16);
}

.lfv4-section-head {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(280px, .48fr);
  gap: clamp(26px, 4vw, 60px);
  align-items: end;
  margin-bottom: 30px;
}

.lfv4-section h2,
.lfv4-proof-card h2,
.lfv4-location-card h2,
.lfv4-booking-card h2,
.lfv4-faq-layout h2,
.lfv4-final-card h2 {
  margin: 16px 0 0;
  max-width: 760px;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  font-size: clamp(2.15rem, 3.25vw, 4.1rem);
  line-height: 1.02;
  letter-spacing: -.058em;
  font-weight: 800;
}

.lfv4-section-head p,
.lfv4-proof-card p,
.lfv4-location-card p,
.lfv4-booking-card p,
.lfv4-final-card p {
  color: var(--v4-muted);
  font-size: 1rem;
  line-height: 1.65;
}

.lfv4-benefit-grid,
.lfv4-service-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.lfv4-benefit,
.lfv4-service {
  min-height: 230px;
  padding: 25px;
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,250,242,.96), rgba(255,250,242,.80));
  border: 1px solid var(--v4-line);
  box-shadow: var(--v4-shadow-soft);
}

.lfv4-benefit h3,
.lfv4-service h3,
.lfv4-review h3 {
  margin: 30px 0 11px;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  font-size: clamp(1.18rem, 1.28vw, 1.42rem);
  line-height: 1.12;
  letter-spacing: -.035em;
}

.lfv4-benefit p,
.lfv4-service p,
.lfv4-review p {
  margin: 0;
  color: var(--v4-muted);
  font-size: .94rem;
  line-height: 1.58;
}

.lfv4-proof-layout,
.lfv4-location-layout {
  display: grid;
  grid-template-columns: .88fr 1.12fr;
  gap: 20px;
  align-items: stretch;
}

.lfv4-proof-card,
.lfv4-location-card,
.lfv4-booking-card,
.lfv4-final-card {
  border-radius: 34px;
  padding: clamp(30px, 4vw, 54px);
  background: rgba(255, 250, 242, .86);
  border: 1px solid var(--v4-line);
  box-shadow: var(--v4-shadow-soft);
}

.lfv4-proof-card {
  background:
    radial-gradient(circle at 88% 12%, rgba(225,173,92,.28), transparent 15rem),
    linear-gradient(145deg, #211107, #3b2112);
  color: #fff8ed;
}

.lfv4-proof-card p {
  color: rgba(255, 248, 237, .78);
}

.lfv4-proof-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

.lfv4-review-panel {
  display: grid;
  gap: 14px;
}

.lfv4-review {
  padding: 24px;
  border-radius: 26px;
  background: rgba(255, 250, 242, .84);
  border: 1px solid var(--v4-line);
  box-shadow: var(--v4-shadow-soft);
}

.lfv4-review-empty {
  min-height: 210px;
}

.lfv4-stars {
  color: var(--v4-copper);
  letter-spacing: .12em;
  font-size: .9rem;
  font-weight: 900;
}

.lfv4-review span {
  display: block;
  margin-top: 14px;
  color: var(--v4-muted);
  font-size: .82rem;
  font-weight: 800;
}

.lfv4-info-list {
  display: grid;
  gap: 12px;
  margin-top: 26px;
}

.lfv4-info-row {
  min-height: 50px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 13px 15px;
  border-radius: 16px;
  color: var(--v4-ink);
  background: rgba(37,24,14,.045);
  text-decoration: none;
  font-size: .94rem;
}

.lfv4-info-row .lf-icon-badge {
  flex: 0 0 auto;
}

.lfv4-faq-layout {
  display: grid;
  grid-template-columns: .62fr 1fr;
  gap: clamp(28px, 5vw, 70px);
}

.lfv4-faq-list {
  display: grid;
  gap: 12px;
}

.lfv4-faq {
  border-radius: 20px;
  background: rgba(255,250,242,.86);
  border: 1px solid var(--v4-line);
  box-shadow: var(--v4-shadow-soft);
  overflow: hidden;
}

.lfv4-faq summary {
  cursor: pointer;
  padding: 18px 20px;
  font-weight: 900;
}

.lfv4-faq p {
  margin: 0;
  padding: 0 20px 20px;
  color: var(--v4-muted);
  line-height: 1.58;
}

.lfv4-final {
  padding: clamp(44px, 5vw, 76px) 0;
}

.lfv4-final-card {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 26px;
  background:
    radial-gradient(circle at 92% 18%, rgba(225,173,92,.22), transparent 14rem),
    rgba(255, 250, 242, .90);
}

.lfv4-footer {
  border-top: 1px solid var(--v4-line);
  padding: 42px 0 56px;
}

.lfv4-footer-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
}

.lfv4-footer strong,
.lfv4-footer span {
  display: block;
}

.lfv4-footer strong {
  font-size: 1.12rem;
}

.lfv4-footer span {
  margin-top: 7px;
  color: var(--v4-muted);
}

.lfv4-mobile-cta {
  display: none;
}

@media (max-width: 1100px) {
  .lfv4-hero-grid,
  .lfv4-proof-layout,
  .lfv4-location-layout,
  .lfv4-faq-layout {
    grid-template-columns: 1fr;
  }

  .lfv4-benefit-grid,
  .lfv4-service-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .lfv4-menu {
    display: none;
  }

  .lfv4-nav {
    grid-template-columns: 1fr auto;
  }
}

@media (max-width: 760px) {
  .lfv4-shell {
    width: min(100% - 22px, 1240px);
  }

  .lfv4-topbar {
    position: relative;
  }

  .lfv4-nav {
    min-height: 66px;
  }

  .lfv4-nav > .lfv4-btn {
    display: none;
  }

  .lfv4-hero {
    padding-top: 26px;
  }

  .lfv4-hero-grid {
    display: flex;
    flex-direction: column;
    gap: 22px;
  }

  .lfv4-hero-copy {
    order: 1;
  }

  .lfv4-hero-card {
    order: 2;
    width: 100%;
    min-height: 365px;
    border-radius: 28px;
    padding: 18px;
  }

  .lfv4-hero-card-inner {
    min-height: 329px;
    padding: 18px;
    border-radius: 22px;
  }

  .lfv4-hero h1 {
    font-size: clamp(2.16rem, 8.6vw, 3.28rem);
    line-height: 1.02;
    letter-spacing: -.052em;
  }

  .lfv4-hero p {
    font-size: .98rem;
  }

  .lfv4-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .lfv4-actions .lfv4-btn {
    width: 100%;
  }

  .lfv4-badge-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lfv4-badge {
    width: 100%;
    justify-content: flex-start;
    font-size: .74rem;
  }

  .lfv4-rating-card {
    min-width: 106px;
    padding: 13px;
  }

  .lfv4-rating-card strong {
    font-size: 2rem;
  }

  .lfv4-hero-card-title {
    font-size: clamp(1.85rem, 8vw, 2.72rem);
  }

  .lfv4-quick-row {
    min-height: 42px;
    font-size: .78rem;
  }

  .lfv4-trust-grid,
  .lfv4-benefit-grid,
  .lfv4-service-grid {
    grid-template-columns: 1fr;
  }

  .lfv4-section {
    padding: 44px 0;
  }

  .lfv4-section-head,
  .lfv4-final-card {
    grid-template-columns: 1fr;
  }

  .lfv4-section h2,
  .lfv4-proof-card h2,
  .lfv4-location-card h2,
  .lfv4-booking-card h2,
  .lfv4-faq-layout h2,
  .lfv4-final-card h2 {
    font-size: clamp(1.92rem, 8vw, 2.86rem);
  }

  .lfv4-benefit,
  .lfv4-service {
    min-height: auto;
  }

  .lfv4-footer-grid {
    grid-template-columns: 1fr;
  }

  .lfv4-mobile-cta {
    position: fixed;
    z-index: 80;
    left: 12px;
    right: 12px;
    bottom: 12px;
    display: block;
  }

  .lfv4-mobile-cta .lfv4-btn {
    width: 100%;
    min-height: 56px;
  }
}

@media (max-width: 440px) {
  .lfv4-badge-row {
    grid-template-columns: 1fr;
  }

  .lfv4-hero-card-top {
    display: grid;
    gap: 12px;
  }

  .lfv4-rating-card {
    width: fit-content;
  }
}


/* =========================================================
   Leadflow Premium v0.4.1
   First-person copy support + mobile hero breathing room
   ========================================================= */

.lfv4-review-empty p {
  max-width: 620px;
}

.lfv4-proof-card p strong {
  color: #fff8ed;
}

@media (max-width: 760px) {
  .lfv4-hero-card {
    min-height: 430px;
  }

  .lfv4-hero-card-inner {
    min-height: 394px;
    justify-content: flex-start;
    gap: 20px;
  }

  .lfv4-hero-card-top {
    margin-bottom: 4px;
  }

  .lfv4-hero-card-title {
    max-width: 100%;
    font-size: clamp(1.9rem, 7.8vw, 2.75rem);
    line-height: 1.03;
    margin: 2px 0 0;
  }

  .lfv4-quick-list {
    margin-top: auto;
    gap: 9px;
  }

  .lfv4-quick-row {
    min-height: 46px;
    border-radius: 14px;
  }
}

@media (max-width: 440px) {
  .lfv4-hero-card {
    min-height: 455px;
  }

  .lfv4-hero-card-inner {
    min-height: 419px;
    gap: 18px;
  }

  .lfv4-hero-card-title {
    font-size: clamp(1.8rem, 8.4vw, 2.55rem);
  }

  .lfv4-rating-card {
    padding: 12px;
  }

  .lfv4-rating-card strong {
    font-size: 1.85rem;
  }
}


/* Leadflow Premium v0.4.2 - real Google review cards */
.lfv4-review-panel {
  grid-template-columns: 1fr;
}

.lfv4-review {
  position: relative;
  min-height: 168px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.lfv4-review p {
  margin-top: 12px;
  font-size: 1rem;
  line-height: 1.62;
}

.lfv4-stars {
  color: #b7742b;
  letter-spacing: .08em;
  font-weight: 900;
}

.lfv4-review span {
  margin-top: 16px;
  font-size: .82rem;
  font-weight: 850;
}

@media (min-width: 980px) {
  .lfv4-review-panel {
    align-content: stretch;
  }

  .lfv4-review {
    min-height: 176px;
  }
}


/* =========================================================
   Leadflow Premium v0.5.0
   Honest abstract visual system - no fake salon photos
   ========================================================= */

.lfv5-visual-section {
  position: relative;
  padding: clamp(54px, 6vw, 92px) 0;
  overflow: hidden;
}

.lfv5-visual-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 22%, rgba(183, 116, 43, .18), transparent 18rem),
    radial-gradient(circle at 86% 18%, rgba(225, 173, 92, .22), transparent 20rem),
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.22));
  pointer-events: none;
}

.lfv5-visual-layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: .82fr 1.18fr;
  gap: clamp(22px, 4vw, 52px);
  align-items: stretch;
}

.lfv5-visual-lead {
  position: relative;
  min-height: 560px;
  border-radius: 38px;
  padding: clamp(32px, 4.5vw, 58px);
  overflow: hidden;
  color: #fff8ed;
  background:
    radial-gradient(circle at 84% 18%, rgba(225, 173, 92, .55), transparent 12rem),
    radial-gradient(circle at 18% 88%, rgba(255, 248, 237, .10), transparent 15rem),
    linear-gradient(145deg, #1a0d06 0%, #3a1f11 58%, #79451f 100%);
  box-shadow: 0 30px 90px rgba(58, 31, 13, .22);
}

.lfv5-visual-lead .lfv4-eyebrow {
  color: rgba(255, 248, 237, .82);
  background: rgba(255,255,255,.11);
}

.lfv5-visual-lead h2 {
  margin: 20px 0 0;
  max-width: 570px;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  font-size: clamp(2.35rem, 3.7vw, 4.7rem);
  line-height: .98;
  letter-spacing: -.065em;
  font-weight: 800;
}

.lfv5-visual-lead p {
  max-width: 520px;
  margin: 22px 0 0;
  color: rgba(255, 248, 237, .78);
  font-size: 1.02rem;
  line-height: 1.65;
}

.lfv5-visual-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 30px;
}

.lfv5-visual-lead .lfv4-btn-secondary {
  color: #fff8ed;
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.18);
}

.lfv5-abstract-mark {
  position: absolute;
  right: -34px;
  bottom: -38px;
  width: min(42vw, 320px);
  color: rgba(255, 248, 237, .09);
  transform: rotate(-12deg);
}

.lfv5-scissors-mark {
  display: block;
  width: 100%;
  height: auto;
}

.lfv5-showcase-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.lfv5-showcase-tile {
  position: relative;
  min-height: 270px;
  border-radius: 34px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255, 250, 242, .96), rgba(255, 250, 242, .82));
  border: 1px solid rgba(37, 24, 14, .12);
  box-shadow: 0 20px 58px rgba(61, 38, 18, .10);
}

.lfv5-tile-art {
  position: absolute;
  inset: 0;
  overflow: hidden;
  background:
    radial-gradient(circle at 72% 18%, rgba(225, 173, 92, .34), transparent 8.8rem),
    radial-gradient(circle at 20% 92%, rgba(183, 116, 43, .12), transparent 10rem);
}

.lfv5-tile-art .lf-icon-badge {
  position: absolute;
  top: 24px;
  left: 24px;
  width: 42px;
  height: 42px;
  border-radius: 15px;
  background: linear-gradient(135deg, #c88635, #8d4f1f);
  z-index: 2;
}

.lfv5-orb {
  position: absolute;
  display: block;
  border-radius: 999px;
  filter: blur(.2px);
}

.lfv5-orb-a {
  width: 170px;
  height: 170px;
  right: -66px;
  top: -64px;
  background: rgba(225, 173, 92, .18);
}

.lfv5-orb-b {
  width: 120px;
  height: 120px;
  right: 28px;
  bottom: 22px;
  border: 28px solid rgba(36, 18, 8, .055);
}

.lfv5-line {
  position: absolute;
  display: block;
  height: 1px;
  width: 170px;
  background: rgba(37, 24, 14, .10);
  transform-origin: center;
}

.lfv5-line-a {
  right: 22px;
  top: 118px;
  transform: rotate(-28deg);
}

.lfv5-line-b {
  right: -24px;
  top: 156px;
  transform: rotate(-28deg);
}

.lfv5-tile-content {
  position: relative;
  z-index: 2;
  height: 100%;
  min-height: 270px;
  padding: 90px 28px 28px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.lfv5-tile-content > span {
  width: fit-content;
  display: inline-flex;
  padding: 7px 10px;
  border-radius: 999px;
  color: #7c5f49;
  background: rgba(37, 24, 14, .055);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .05em;
}

.lfv5-tile-content h3 {
  margin: 15px 0 10px;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  font-size: clamp(1.35rem, 1.7vw, 1.85rem);
  line-height: 1.05;
  letter-spacing: -.045em;
}

.lfv5-tile-content p {
  margin: 0;
  max-width: 360px;
  color: #765f4f;
  font-size: .94rem;
  line-height: 1.55;
}

.lfv5-showcase-tile-haarschnitt {
  background:
    linear-gradient(145deg, rgba(255,250,242,.96), rgba(247,230,204,.82));
}

.lfv5-showcase-tile-termin {
  background:
    radial-gradient(circle at 86% 12%, rgba(183,116,43,.20), transparent 8rem),
    linear-gradient(180deg, rgba(255,250,242,.96), rgba(255,250,242,.82));
}

.lfv5-showcase-tile-bewertung {
  background:
    radial-gradient(circle at 82% 18%, rgba(225,173,92,.27), transparent 9rem),
    linear-gradient(180deg, rgba(255,250,242,.96), rgba(255,250,242,.82));
}

@media (max-width: 1050px) {
  .lfv5-visual-layout {
    grid-template-columns: 1fr;
  }

  .lfv5-visual-lead {
    min-height: 420px;
  }
}

@media (max-width: 760px) {
  .lfv5-visual-section {
    padding: 44px 0;
  }

  .lfv5-showcase-grid {
    grid-template-columns: 1fr;
  }

  .lfv5-visual-lead {
    min-height: auto;
    border-radius: 30px;
    padding: 30px;
  }

  .lfv5-visual-lead h2 {
    font-size: clamp(2rem, 8vw, 3rem);
  }

  .lfv5-visual-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .lfv5-visual-actions .lfv4-btn {
    width: 100%;
  }

  .lfv5-showcase-tile {
    min-height: 230px;
    border-radius: 28px;
  }

  .lfv5-tile-content {
    min-height: 230px;
    padding: 82px 24px 24px;
  }
}


/* =========================================================
   Leadflow Premium v0.5.1
   Richer abstract visual tiles
   ========================================================= */

.lfv5-visual-lead {
  min-height: 520px;
}

.lfv5-visual-lead h2 {
  max-width: 480px;
  font-size: clamp(2.25rem, 3.35vw, 4.25rem);
}

.lfv5-showcase-grid {
  gap: 16px;
}

.lfv5-showcase-tile-rich {
  min-height: 255px;
  border-radius: 32px;
  isolation: isolate;
  background:
    radial-gradient(circle at 82% 10%, rgba(225, 173, 92, .34), transparent 9rem),
    linear-gradient(145deg, rgba(255, 250, 242, .98), rgba(247, 229, 202, .82));
}

.lfv5-showcase-tile-rich::before {
  content: "";
  position: absolute;
  inset: 12px;
  border-radius: 24px;
  border: 1px solid rgba(37, 24, 14, .08);
  pointer-events: none;
  z-index: 2;
}

.lfv5-rich-art {
  position: absolute;
  inset: 0;
  overflow: hidden;
  z-index: 1;
}

.lfv5-rich-icon {
  position: absolute;
  right: 26px;
  top: 26px;
  width: 82px;
  height: 82px;
  display: grid;
  place-items: center;
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(183,116,43,.16), rgba(255,250,242,.20));
  border: 1px solid rgba(37,24,14,.08);
}

.lfv5-rich-icon .lf-icon-badge {
  width: 48px;
  height: 48px;
  border-radius: 18px;
  background: linear-gradient(135deg, #c88635, #8d4f1f);
}

.lfv5-rich-icon .lf-icon-badge svg {
  width: 22px;
  height: 22px;
}

.lfv5-rich-orb {
  position: absolute;
  border-radius: 999px;
  display: block;
}

.lfv5-rich-orb-a {
  width: 190px;
  height: 190px;
  right: -78px;
  top: -78px;
  background: rgba(225, 173, 92, .22);
}

.lfv5-rich-orb-b {
  width: 142px;
  height: 142px;
  right: 28px;
  bottom: -38px;
  border: 30px solid rgba(36, 18, 8, .055);
}

.lfv5-rich-line {
  position: absolute;
  display: block;
  width: 190px;
  height: 1px;
  background: rgba(37, 24, 14, .10);
  transform-origin: center;
}

.lfv5-rich-line-a {
  right: 72px;
  top: 112px;
  transform: rotate(-26deg);
}

.lfv5-rich-line-b {
  right: 34px;
  top: 144px;
  transform: rotate(-26deg);
}

.lfv5-rich-content {
  position: relative;
  z-index: 3;
  min-height: 255px;
  padding: 28px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.lfv5-rich-topline {
  position: absolute;
  top: 26px;
  left: 28px;
  right: 124px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.lfv5-rich-topline span {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 13px;
  color: #fff8ed;
  background: linear-gradient(135deg, #c88635, #8d4f1f);
  font-size: .74rem;
  font-weight: 950;
}

.lfv5-rich-topline small {
  color: #7c604a;
  font-size: .75rem;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.lfv5-showcase-tile-rich h3 {
  margin: 0 0 10px;
  max-width: 260px;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  font-size: clamp(1.42rem, 1.8vw, 2rem);
  line-height: 1.04;
  letter-spacing: -.05em;
}

.lfv5-showcase-tile-rich p {
  margin: 0;
  max-width: 330px;
  color: #725b4b;
  font-size: .94rem;
  line-height: 1.55;
}

.lfv5-rich-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}

.lfv5-rich-chips span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  color: #6f553e;
  background: rgba(255, 250, 242, .74);
  border: 1px solid rgba(37, 24, 14, .08);
  font-size: .72rem;
  font-weight: 780;
}

.lfv5-showcase-tile-beratung {
  background:
    radial-gradient(circle at 82% 12%, rgba(225,173,92,.34), transparent 9rem),
    linear-gradient(145deg, #fffaf2, #f4dfbf);
}

.lfv5-showcase-tile-haarschnitt {
  background:
    radial-gradient(circle at 82% 12%, rgba(183,116,43,.28), transparent 9rem),
    linear-gradient(145deg, #fffaf2, #f1d7ad);
}

.lfv5-showcase-tile-styling {
  background:
    radial-gradient(circle at 82% 12%, rgba(225,173,92,.24), transparent 9rem),
    linear-gradient(145deg, #fffaf2, #f5e6cc);
}

.lfv5-showcase-tile-termin {
  background:
    radial-gradient(circle at 82% 12%, rgba(183,116,43,.31), transparent 9rem),
    linear-gradient(145deg, #fffaf2, #efd4aa);
}

@media (max-width: 1050px) {
  .lfv5-visual-lead {
    min-height: 390px;
  }
}

@media (max-width: 760px) {
  .lfv5-showcase-tile-rich {
    min-height: 245px;
  }

  .lfv5-rich-content {
    min-height: 245px;
    padding: 24px;
  }

  .lfv5-rich-topline {
    top: 24px;
    left: 24px;
    right: 104px;
  }

  .lfv5-rich-icon {
    right: 22px;
    top: 22px;
    width: 72px;
    height: 72px;
    border-radius: 24px;
  }

  .lfv5-rich-icon .lf-icon-badge {
    width: 42px;
    height: 42px;
  }

  .lfv5-showcase-tile-rich h3 {
    font-size: clamp(1.35rem, 7vw, 1.8rem);
  }

  .lfv5-rich-chips {
    margin-top: 14px;
  }
}


/* =========================================================
   Leadflow Premium v0.5.2
   Visual tile overlap + CTA artifact polish
   ========================================================= */

/* Prevent abstract mark from visually cutting through CTA buttons */
.lfv5-visual-lead > .lfv4-eyebrow,
.lfv5-visual-lead h2,
.lfv5-visual-lead p,
.lfv5-visual-actions {
  position: relative;
  z-index: 4;
}

.lfv5-abstract-mark {
  z-index: 1;
  opacity: .78;
  pointer-events: none;
  right: -76px;
  bottom: -74px;
}

.lfv5-visual-actions .lfv4-btn {
  position: relative;
  z-index: 5;
  overflow: hidden;
}

.lfv5-visual-actions .lfv4-btn-primary {
  background: linear-gradient(135deg, #1a0e07 0%, #6d3b18 58%, #bd7a2f 100%);
  box-shadow: 0 18px 42px rgba(87, 46, 17, .22);
}

/* Rich tile layout: keep label, headline and decorative lines separated */
.lfv5-showcase-tile-rich {
  min-height: 270px;
}

.lfv5-rich-content {
  min-height: 270px;
  justify-content: flex-start;
  padding: 28px;
}

.lfv5-rich-topline {
  position: relative;
  top: auto;
  left: auto;
  right: auto;
  width: calc(100% - 126px);
  min-height: 34px;
  margin-bottom: 42px;
  z-index: 5;
}

.lfv5-showcase-tile-rich h3 {
  margin: 0 0 12px;
  max-width: 280px;
  position: relative;
  z-index: 5;
}

.lfv5-showcase-tile-rich p {
  position: relative;
  z-index: 5;
}

.lfv5-rich-chips {
  position: relative;
  z-index: 5;
  margin-top: auto;
  padding-top: 18px;
}

.lfv5-rich-art {
  z-index: 1;
}

.lfv5-rich-line {
  opacity: .28;
  width: 150px;
  right: 22px;
}

.lfv5-rich-line-a {
  top: 116px;
  transform: rotate(-24deg);
}

.lfv5-rich-line-b {
  top: 146px;
  transform: rotate(-24deg);
}

.lfv5-rich-orb-b {
  opacity: .58;
}

.lfv5-rich-icon {
  z-index: 4;
}

/* Slightly calmer top-right glow so it does not compete with content */
.lfv5-rich-orb-a {
  opacity: .82;
}

@media (max-width: 760px) {
  .lfv5-showcase-tile-rich {
    min-height: 270px;
  }

  .lfv5-rich-content {
    min-height: 270px;
    padding: 24px;
  }

  .lfv5-rich-topline {
    width: calc(100% - 104px);
    margin-bottom: 36px;
  }

  .lfv5-rich-line {
    opacity: .22;
    right: 6px;
  }

  .lfv5-rich-line-a {
    top: 112px;
  }

  .lfv5-rich-line-b {
    top: 140px;
  }

  .lfv5-abstract-mark {
    right: -96px;
    bottom: -88px;
    opacity: .62;
  }
}


/* =========================================================
   Leadflow Premium v0.5.3
   Button artifact fix + public copy polish
   ========================================================= */

/* Remove bright left-edge artifact on all colored CTA buttons */
.lfv4-btn-primary,
.lfv5-visual-actions .lfv4-btn-primary,
.lfv4-proof-actions .lfv4-btn-primary,
.lfv4-mobile-cta .lfv4-btn-primary {
  border: 0 !important;
  outline: 0;
  background-color: #5f3416 !important;
  background-image: linear-gradient(135deg, #1b0e07 0%, #5e3215 58%, #b7742b 100%) !important;
  background-origin: border-box;
  background-clip: border-box;
  box-shadow:
    inset 0 0 0 1px rgba(255, 248, 237, .08),
    0 18px 42px rgba(87, 46, 17, .22) !important;
  overflow: hidden;
  isolation: isolate;
}

/* Ensure no decorative background can shine through the button edge */
.lfv4-btn-primary::before,
.lfv4-btn-primary::after {
  content: none !important;
  display: none !important;
}

/* Keep secondary buttons clean and separated */
.lfv4-btn-secondary {
  background: rgba(255, 250, 242, .94) !important;
  box-shadow: inset 0 0 0 1px rgba(37, 24, 14, .10);
}

/* FAQ wording/card readability polish */
.lfv4-faq summary {
  line-height: 1.35;
}

.lfv4-faq p {
  color: #6f5948;
}


/* =========================================================
   Leadflow Premium v0.5.4
   Secondary button contrast fix in dark sections
   ========================================================= */

/* White secondary buttons on dark cards need dark text */
.lfv5-visual-lead .lfv4-btn-secondary,
.lfv4-proof-card .lfv4-btn-secondary,
.lfv4-hero-card .lfv4-btn-secondary,
.lfv4-final-card .lfv4-btn-secondary {
  color: #160d08 !important;
  background: #fffaf2 !important;
  background-image: none !important;
  border: 0 !important;
  box-shadow:
    inset 0 0 0 1px rgba(37, 24, 14, .10),
    0 14px 34px rgba(20, 10, 4, .16) !important;
  text-shadow: none !important;
}

/* Keep primary CTA text white */
.lfv4-btn-primary,
.lfv5-visual-lead .lfv4-btn-primary,
.lfv4-proof-card .lfv4-btn-primary,
.lfv4-mobile-cta .lfv4-btn-primary {
  color: #fff8ed !important;
}

/* Secondary hover remains readable */
.lfv5-visual-lead .lfv4-btn-secondary:hover,
.lfv4-proof-card .lfv4-btn-secondary:hover,
.lfv4-hero-card .lfv4-btn-secondary:hover,
.lfv4-final-card .lfv4-btn-secondary:hover {
  color: #160d08 !important;
  background: #ffffff !important;
}


/* =========================================================
   Leadflow Premium v0.7.0
   Brand assets: colors, logo, website image gallery
   ========================================================= */

.lfe-generated-logo,
.lfe-brand-logo-img {
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  margin-right: 10px;
  vertical-align: middle;
}

.lfe-generated-logo {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  color: #fff8ed;
  background: linear-gradient(135deg, var(--lf-brand-primary, #6d3b18), var(--lf-brand-secondary, #b7742b));
  font-size: .82rem;
  font-weight: 950;
  letter-spacing: -.04em;
  box-shadow: 0 12px 28px rgba(40, 20, 8, .14);
}

.lfe-brand-logo-img {
  width: auto;
  max-width: 150px;
  max-height: 46px;
  object-fit: contain;
}

.lfe-brand-gallery-section {
  padding: clamp(54px, 6vw, 92px) 0;
}

.lfe-brand-gallery {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.lfe-brand-gallery-card {
  position: relative;
  margin: 0;
  min-height: 260px;
  overflow: hidden;
  border-radius: 30px;
  border: 1px solid rgba(37, 24, 14, .10);
  box-shadow: 0 20px 58px rgba(61, 38, 18, .10);
  background: rgba(255, 250, 242, .72);
}

.lfe-brand-gallery-card img {
  width: 100%;
  height: 100%;
  min-height: 260px;
  display: block;
  object-fit: cover;
  transform: scale(1.01);
}

.lfe-brand-gallery-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, transparent 48%, rgba(24, 12, 6, .28)),
    radial-gradient(circle at 80% 10%, rgba(255,255,255,.20), transparent 9rem);
  pointer-events: none;
}

@media (max-width: 1050px) {
  .lfe-brand-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .lfe-brand-gallery {
    grid-template-columns: 1fr;
  }

  .lfe-brand-gallery-card,
  .lfe-brand-gallery-card img {
    min-height: 230px;
  }
}


/* =========================================================
   Leadflow Premium v0.7.1
   Stronger full-site brand theming
   ========================================================= */

:root {
  --lf-brand-primary: var(--lf-brand-primary, #6d3b18);
  --lf-brand-secondary: var(--lf-brand-secondary, #b7742b);
  --lf-brand-accent: var(--lf-brand-accent, #dba35b);

  --lf-page-bg: color-mix(in srgb, var(--lf-brand-primary) 8%, #fbf3e7);
  --lf-page-bg-2: color-mix(in srgb, var(--lf-brand-secondary) 10%, #fffaf2);
  --lf-surface: color-mix(in srgb, var(--lf-brand-primary) 4%, #fffaf4);
  --lf-surface-strong: color-mix(in srgb, var(--lf-brand-secondary) 9%, #fff7ec);
  --lf-dark: color-mix(in srgb, var(--lf-brand-primary) 74%, #140803);
  --lf-dark-2: color-mix(in srgb, var(--lf-brand-secondary) 42%, #190904);
  --lf-border-brand: color-mix(in srgb, var(--lf-brand-primary) 18%, rgba(36, 22, 12, .14));
  --lf-shadow-brand: color-mix(in srgb, var(--lf-brand-primary) 16%, transparent);
}

html,
body {
  background:
    radial-gradient(circle at 76% 8%, color-mix(in srgb, var(--lf-brand-secondary) 18%, transparent) 0, transparent 28rem),
    radial-gradient(circle at 9% 26%, color-mix(in srgb, var(--lf-brand-primary) 9%, transparent) 0, transparent 22rem),
    linear-gradient(180deg, var(--lf-page-bg-2), var(--lf-page-bg)) !important;
}

body::before {
  opacity: .52 !important;
}

.lfv4-header,
.site-header,
header.lfv4-site-header,
.lfv4-topbar,
.lfv4-nav-wrap {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--lf-brand-primary) 7%, #fffaf3), color-mix(in srgb, var(--lf-brand-secondary) 7%, #fff7ed)) !important;
  border-color: var(--lf-border-brand) !important;
}

.lfv4-footer,
.site-footer,
footer {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--lf-brand-primary) 10%, #f4eadb), color-mix(in srgb, var(--lf-brand-secondary) 11%, #efe2d0)) !important;
  border-color: var(--lf-border-brand) !important;
}

.lfv4-hero-card,
.lfv4-visual-card,
.lfv5-visual-panel,
.lfv5-dark-panel,
.lfv4-review-hero,
.lfv4-proof-panel,
.lfv5-rich-intro {
  background:
    radial-gradient(circle at 74% 18%, color-mix(in srgb, var(--lf-brand-secondary) 50%, transparent), transparent 16rem),
    linear-gradient(135deg, var(--lf-dark), var(--lf-dark-2)) !important;
  border-color: color-mix(in srgb, var(--lf-brand-secondary) 22%, rgba(255,255,255,.18)) !important;
}

.lfv4-card,
.lfv4-stat,
.lfv4-service-card,
.lfv5-rich-card,
.lfv4-contact-card,
.lfv4-faq-item,
.lfv4-review,
.lfe-brand-gallery-card,
.lfv4-panel,
.lfv4-soft-card,
.lfv4-location-card {
  background:
    linear-gradient(145deg, var(--lf-surface), var(--lf-surface-strong)) !important;
  border-color: var(--lf-border-brand) !important;
  box-shadow: 0 22px 60px color-mix(in srgb, var(--lf-brand-primary) 9%, transparent) !important;
}

.lfv4-section:nth-of-type(even),
.lfv5-rich-section:nth-of-type(even),
.lfe-brand-gallery-section {
  background:
    radial-gradient(circle at 85% 2%, color-mix(in srgb, var(--lf-brand-secondary) 10%, transparent), transparent 24rem),
    linear-gradient(180deg, color-mix(in srgb, var(--lf-brand-primary) 5%, transparent), transparent) !important;
}

.lfv4-btn-primary,
.lfv5-visual-actions .lfv4-btn-primary,
.lfv4-proof-actions .lfv4-btn-primary,
a.lfv4-btn-primary,
button.lfv4-btn-primary {
  background:
    linear-gradient(135deg, var(--lf-brand-primary), var(--lf-brand-secondary)) !important;
  color: #fffaf2 !important;
  border-color: color-mix(in srgb, var(--lf-brand-secondary) 40%, transparent) !important;
}

.lfv4-btn-secondary,
a.lfv4-btn-secondary {
  background: color-mix(in srgb, var(--lf-brand-secondary) 5%, #fffaf4) !important;
  border-color: color-mix(in srgb, var(--lf-brand-primary) 16%, rgba(30,20,10,.12)) !important;
  color: color-mix(in srgb, var(--lf-brand-primary) 76%, #160904) !important;
}

.lfv4-eyebrow,
.lfv4-stars,
.lfv4-rating,
.lfv4-kicker,
.lfv5-rich-label,
.lfv5-rich-topline,
.lfv4-section-label {
  color: var(--lf-brand-secondary) !important;
}

.lf-icon-badge,
.lfv5-rich-icon .lf-icon-badge,
.lfv4-badge-dot,
.lfv4-trust-pill-icon {
  background: linear-gradient(135deg, var(--lf-brand-secondary), var(--lf-brand-primary)) !important;
}

.lfe-generated-logo {
  background: linear-gradient(135deg, var(--lf-brand-primary), var(--lf-brand-secondary)) !important;
}

.lfe-brand-gallery-section .lfv4-section-heading p {
  max-width: 760px;
}


/* =========================================================
   Leadflow Premium v0.7.2
   Harmonized UI palette, not raw crawled colors
   ========================================================= */

html,
body {
  background:
    radial-gradient(circle at 84% 7%, color-mix(in srgb, var(--lf-brand-secondary) 10%, transparent), transparent 34rem),
    radial-gradient(circle at 8% 31%, color-mix(in srgb, var(--lf-brand-accent) 7%, transparent), transparent 28rem),
    linear-gradient(180deg, var(--lf-brand-surface), var(--lf-brand-background)) !important;
}

.lfv4-header,
.site-header,
header,
.lfv4-topbar {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--lf-brand-surface) 92%, white), color-mix(in srgb, var(--lf-brand-background) 90%, white)) !important;
}

.lfv4-footer,
.site-footer,
footer {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--lf-brand-background) 82%, var(--lf-brand-surface-strong)), color-mix(in srgb, var(--lf-brand-surface-strong) 70%, white)) !important;
}

.lfv4-hero-card,
.lfv4-visual-card,
.lfv5-visual-panel,
.lfv5-dark-panel,
.lfv4-review-hero,
.lfv4-proof-panel,
.lfv5-rich-intro {
  background:
    radial-gradient(circle at 72% 18%, color-mix(in srgb, var(--lf-brand-secondary) 26%, transparent), transparent 18rem),
    linear-gradient(135deg, var(--lf-brand-dark), var(--lf-brand-dark-2)) !important;
}

.lfv4-card,
.lfv4-stat,
.lfv4-service-card,
.lfv5-rich-card,
.lfv4-contact-card,
.lfv4-faq-item,
.lfv4-review,
.lfe-brand-gallery-card,
.lfv4-panel,
.lfv4-soft-card,
.lfv4-location-card {
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--lf-brand-surface) 96%, white), color-mix(in srgb, var(--lf-brand-surface-strong) 72%, white)) !important;
  border-color: color-mix(in srgb, var(--lf-brand-primary) 14%, rgba(36,22,12,.12)) !important;
}

.lfv4-section:nth-of-type(even),
.lfv5-rich-section:nth-of-type(even),
.lfe-brand-gallery-section {
  background:
    radial-gradient(circle at 92% 4%, color-mix(in srgb, var(--lf-brand-secondary) 7%, transparent), transparent 26rem),
    transparent !important;
}

.lfv4-eyebrow,
.lfv4-stars,
.lfv4-rating,
.lfv4-kicker,
.lfv5-rich-label,
.lfv5-rich-topline,
.lfv4-section-label {
  color: var(--lf-brand-secondary) !important;
}

.lfv4-btn-primary,
a.lfv4-btn-primary,
button.lfv4-btn-primary {
  color: #fffaf2 !important;
}

.lfv4-btn-secondary,
a.lfv4-btn-secondary {
  background: color-mix(in srgb, var(--lf-brand-surface) 92%, white) !important;
  color: color-mix(in srgb, var(--lf-brand-dark) 88%, #000) !important;
}

/* =========================================================
   Leadflow Premium H5
   Stronger harmonized background + generated logo usage
   ========================================================= */

html,
body {
  background:
    radial-gradient(circle at 82% 10%, color-mix(in srgb, var(--lf-brand-secondary) 16%, transparent), transparent 34rem),
    radial-gradient(circle at 10% 28%, color-mix(in srgb, var(--lf-brand-primary) 12%, transparent), transparent 30rem),
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--lf-brand-surface) 76%, var(--lf-brand-secondary) 8%),
      color-mix(in srgb, var(--lf-brand-background) 82%, var(--lf-brand-primary) 12%)
    ) !important;
}

.lfv4-topbar {
  background:
    linear-gradient(
      90deg,
      color-mix(in srgb, var(--lf-brand-surface) 82%, var(--lf-brand-background)),
      color-mix(in srgb, var(--lf-brand-background) 84%, var(--lf-brand-secondary) 6%)
    ) !important;
}

.lfv4-section-soft,
.lfv4-final,
.lfe-brand-gallery-section {
  background:
    radial-gradient(circle at 90% 4%, color-mix(in srgb, var(--lf-brand-secondary) 10%, transparent), transparent 26rem),
    color-mix(in srgb, var(--lf-brand-background) 86%, var(--lf-brand-surface-strong)) !important;
}

.lfv4-brand {
  flex-direction: row !important;
  align-items: center !important;
  gap: 10px !important;
}

.lfv4-brand-copy {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0;
}

.lfv4-brand .lfv4-brand-name {
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif !important;
  font-size: 1.18rem !important;
  font-weight: 850 !important;
  letter-spacing: -.04em !important;
  line-height: 1 !important;
  text-decoration: underline !important;
  text-underline-offset: 4px !important;
}

.lfv4-brand small {
  margin-top: 5px !important;
}

.lfv4-brand .lfe-generated-logo,
.lfv4-footer-brand .lfe-generated-logo {
  margin-right: 0 !important;
  text-decoration: none !important;
}

.lfe-generated-logo-mark,
.lfe-generated-logo {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: inline-grid;
  place-items: center;
  color: #fffaf2;
  background:
    linear-gradient(135deg, var(--lf-brand-primary), var(--lf-brand-secondary));
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: .82rem;
  font-weight: 950;
  letter-spacing: -.04em;
  box-shadow: 0 12px 28px color-mix(in srgb, var(--lf-brand-primary) 24%, transparent);
  flex: 0 0 auto;
}

.lfe-generated-logo-wordmark {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.lfe-generated-logo-text {
  font-weight: 900;
  letter-spacing: -.04em;
  color: var(--lf-brand-dark);
}

.lfv4-footer-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

.lfv4-footer-brand > span {
  display: grid;
  gap: 4px;
}


/* =========================================================
   Leadflow H10 emergency polish
   - compact generated wordmark
   - high-contrast CTAs
   - neutralize leftover brown/gold v5 tile colors
   ========================================================= */

:root {
  --lf-brand-dark-2: #3f4650;
}

.lfv4 {
  --v4-brown: var(--lf-brand-dark);
  --v4-brown-2: var(--lf-brand-dark-2);
  --v4-gold: color-mix(in srgb, var(--lf-brand-accent) 78%, white);
  --v4-copper: var(--lf-brand-secondary);
}

/* Header logo/wordmark spacing */
.lfv4-brand {
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 12px !important;
  text-decoration: none !important;
  min-width: 0;
}

.lfv4-brand-copy {
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
  line-height: 1.05 !important;
  min-width: 0;
}

.lfv4-brand .lfv4-brand-name {
  display: block !important;
  margin: 0 !important;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif !important;
  font-size: clamp(1.04rem, 1vw, 1.22rem) !important;
  font-weight: 900 !important;
  letter-spacing: -.04em !important;
  line-height: 1 !important;
  text-decoration: underline !important;
  text-underline-offset: 4px !important;
}

.lfv4-brand small {
  display: block !important;
  margin: 0 !important;
  color: color-mix(in srgb, var(--lf-brand-primary) 70%, #5f6670) !important;
  font-size: .78rem !important;
  line-height: 1.15 !important;
}

/* Generated logo mark: make it intentional, not broken */
.lfe-generated-logo {
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
  border-radius: 14px !important;
  display: inline-grid !important;
  place-items: center !important;
  margin: 0 !important;
  background:
    linear-gradient(135deg, var(--lf-brand-primary), var(--lf-brand-secondary)) !important;
  color: #fffaf2 !important;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif !important;
  font-size: 1rem !important;
  font-weight: 900 !important;
  letter-spacing: -.08em !important;
  line-height: 1 !important;
  box-shadow: 0 12px 28px color-mix(in srgb, var(--lf-brand-primary) 20%, transparent) !important;
}

.lfe-generated-logo::after {
  content: "";
  position: absolute;
  inset: 5px;
  border: 1px solid rgba(255,255,255,.34);
  border-radius: 10px;
  pointer-events: none;
}

/* Footer logo layout */
.lfv4-footer-brand {
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
}

.lfv4-footer-brand > span {
  display: grid !important;
  gap: 3px !important;
}

.lfv4-footer-brand strong {
  margin: 0 !important;
  line-height: 1.05 !important;
}

.lfv4-footer-brand span span {
  margin: 0 !important;
  line-height: 1.2 !important;
}

/* Buttons: force real pill styling everywhere, especially v5 visual block */
.lfv4-btn,
a.lfv4-btn,
.lfv5-visual-actions .lfv4-btn,
.lfv4-actions .lfv4-btn,
.lfv4-proof-actions .lfv4-btn {
  min-height: 48px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 999px !important;
  padding: 0 24px !important;
  border: 1px solid transparent !important;
  text-decoration: none !important;
  font-weight: 900 !important;
  font-size: .94rem !important;
  line-height: 1 !important;
  position: relative !important;
  z-index: 8 !important;
}

.lfv4-btn-primary,
a.lfv4-btn-primary,
.lfv5-visual-actions .lfv4-btn-primary,
.lfv4-actions .lfv4-btn-primary,
.lfv4-proof-actions .lfv4-btn-primary {
  background:
    linear-gradient(135deg, var(--lf-brand-primary), var(--lf-brand-secondary)) !important;
  color: #fffaf2 !important;
  border-color: color-mix(in srgb, var(--lf-brand-secondary) 38%, transparent) !important;
  box-shadow: 0 16px 38px color-mix(in srgb, var(--lf-brand-primary) 22%, transparent) !important;
}

.lfv4-btn-secondary,
a.lfv4-btn-secondary,
.lfv5-visual-actions .lfv4-btn-secondary,
.lfv4-actions .lfv4-btn-secondary,
.lfv4-proof-actions .lfv4-btn-secondary {
  background: color-mix(in srgb, var(--lf-brand-surface) 94%, white) !important;
  color: color-mix(in srgb, var(--lf-brand-dark) 92%, black) !important;
  border-color: color-mix(in srgb, var(--lf-brand-primary) 18%, rgba(20,26,34,.16)) !important;
  box-shadow: 0 12px 28px color-mix(in srgb, var(--lf-brand-primary) 10%, transparent) !important;
}

.lfv5-visual-actions {
  display: flex !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  position: relative !important;
  z-index: 9 !important;
}

/* Remove leftover brown/gold tile palette */
.lfv5-showcase-tile,
.lfv5-showcase-tile-rich,
.lfv5-showcase-tile-beratung,
.lfv5-showcase-tile-haarschnitt,
.lfv5-showcase-tile-styling,
.lfv5-showcase-tile-termin,
.lfv5-showcase-tile-route,
.lfv5-showcase-tile-bewertung {
  background:
    radial-gradient(circle at 82% 10%, color-mix(in srgb, var(--lf-brand-accent) 22%, transparent), transparent 9rem),
    linear-gradient(145deg,
      color-mix(in srgb, var(--lf-brand-surface) 92%, white),
      color-mix(in srgb, var(--lf-brand-surface-strong) 76%, white)
    ) !important;
  border-color: color-mix(in srgb, var(--lf-brand-primary) 14%, rgba(20,26,34,.12)) !important;
}

.lfv5-rich-icon {
  background:
    linear-gradient(135deg,
      color-mix(in srgb, var(--lf-brand-secondary) 18%, white),
      color-mix(in srgb, var(--lf-brand-primary) 10%, white)
    ) !important;
  border-color: color-mix(in srgb, var(--lf-brand-primary) 12%, rgba(20,26,34,.12)) !important;
}

.lfv5-rich-icon .lf-icon-badge,
.lfv5-rich-topline span {
  background:
    linear-gradient(135deg, var(--lf-brand-primary), var(--lf-brand-secondary)) !important;
  color: #fffaf2 !important;
}

.lfv5-rich-orb-a {
  background: color-mix(in srgb, var(--lf-brand-accent) 20%, transparent) !important;
}

.lfv5-rich-orb-b {
  border-color: color-mix(in srgb, var(--lf-brand-primary) 7%, transparent) !important;
}

.lfv5-rich-line {
  background: color-mix(in srgb, var(--lf-brand-primary) 12%, transparent) !important;
}

.lfv5-showcase-tile-rich p,
.lfv5-tile-content p {
  color: color-mix(in srgb, var(--lf-brand-dark) 72%, #5f6670) !important;
}

.lfv5-rich-chips span,
.lfv5-tile-content > span {
  color: color-mix(in srgb, var(--lf-brand-primary) 76%, #222832) !important;
  background: color-mix(in srgb, var(--lf-brand-surface) 88%, white) !important;
  border-color: color-mix(in srgb, var(--lf-brand-primary) 10%, rgba(20,26,34,.12)) !important;
}

/* Dark panels should be graphite/rose, not brown */
.lfv4-hero-card,
.lfv5-visual-lead,
.lfv4-proof-card {
  background:
    radial-gradient(circle at 72% 18%, color-mix(in srgb, var(--lf-brand-secondary) 24%, transparent), transparent 18rem),
    linear-gradient(135deg, var(--lf-brand-dark), var(--lf-brand-dark-2)) !important;
}

@media (max-width: 760px) {
  .lfv5-visual-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .lfv5-visual-actions .lfv4-btn {
    width: 100% !important;
  }
}


/* Leadflow H11b stylesheet fallback */
.lfv4 a,
.lfv4-brand,
.lfv4-brand *,
.lfv4-footer * {
  text-decoration: none !important;
}

@media (max-width: 760px) {
  .lfv4-actions .lfv4-btn,
  .lfv5-visual-actions .lfv4-btn {
    width: auto !important;
  }

  .lfv4-brand,
  .lfv4-footer-brand {
    align-items: center !important;
    text-align: center !important;
  }
}


/* Leadflow H12 stylesheet fallback */
@media (max-width: 760px) {
  .lfv4-nav > .lfv4-btn,
  .lfv4-nav > a.lfv4-btn {
    display: none !important;
  }

  .lfv4-footer-brand,
  .lfv4-brand {
    text-align: center !important;
  }
}


/* Leadflow H13 stylesheet fallback */
@media (min-width: 761px) {
  .lfv4-nav {
    grid-template-columns: minmax(260px, 1fr) auto minmax(260px, 1fr) !important;
  }

  .lfv4-menu {
    grid-column: 2 !important;
    justify-self: center !important;
  }

  .lfv4-nav > .lfv4-btn,
  .lfv4-nav > a.lfv4-btn {
    grid-column: 3 !important;
    justify-self: end !important;
  }
}

.lfv5-visual-section::before {
  background:
    radial-gradient(circle at 17% 20%, color-mix(in srgb, var(--lf-brand-secondary) 26%, transparent), transparent 23rem),
    radial-gradient(circle at 83% 14%, color-mix(in srgb, var(--lf-brand-primary) 13%, transparent), transparent 24rem),
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.18)) !important;
}


/* Leadflow G2-FIX2: visual/showcase artifact cleanup fallback */
.lfv5-rich-line,
.lfv5-rich-orb-a,
.lfv5-rich-orb-b,
.lfv5-line,
.lfv5-orb-a,
.lfv5-orb-b,
.lfv5-showcase-tile-rich::before,
.lfv5-showcase-tile-rich::after,
.lfv5-showcase-grid::before,
.lfv5-showcase-grid::after,
.lfv5-visual-layout::before,
.lfv5-visual-layout::after {
  content: none !important;
  display: none !important;
  opacity: 0 !important;
}

.lfv5-showcase-tile-rich,
.lfv5-showcase-tile {
  overflow: hidden !important;
  outline: 0 !important;
}

.lfv5-showcase-grid,
.lfv5-visual-layout,
.lfv5-visual-section {
  border: 0 !important;
  outline: 0 !important;
}


/* Leadflow G2-FIX2b: stronger showcase artifact cleanup */
.lfv5-showcase-grid,
.lfv5-visual-layout,
.lfv5-visual-section {
  border: 0 !important;
  outline: 0 !important;
}

.lfv5-showcase-tile-rich,
.lfv5-showcase-tile {
  overflow: hidden !important;
  outline: 0 !important;
}

.lfv5-showcase-tile-rich::before,
.lfv5-showcase-tile-rich::after,
.lfv5-showcase-tile::before,
.lfv5-showcase-tile::after,
.lfv5-showcase-grid::before,
.lfv5-showcase-grid::after,
.lfv5-visual-layout::before,
.lfv5-visual-layout::after,
.lfv5-rich-line,
.lfv5-rich-orb-a,
.lfv5-rich-orb-b,
.lfv5-line,
.lfv5-orb-a,
.lfv5-orb-b {
  content: none !important;
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  transform: none !important;
}

@media (max-width: 760px) {
  .lfv5-showcase-tile-rich,
  .lfv5-showcase-tile {
    min-height: auto !important;
  }
}


/* Leadflow G2-FIX2c: emergency visual artifact cleanup */
.lfv5-showcase-grid,
.lfv5-visual-layout,
.lfv5-visual-section {
  border: 0 !important;
  outline: 0 !important;
}

.lfv5-showcase-tile-rich,
.lfv5-showcase-tile {
  overflow: hidden !important;
  outline: 0 !important;
}

.lfv5-showcase-tile-rich::before,
.lfv5-showcase-tile-rich::after,
.lfv5-showcase-tile::before,
.lfv5-showcase-tile::after,
.lfv5-showcase-grid::before,
.lfv5-showcase-grid::after,
.lfv5-visual-layout::before,
.lfv5-visual-layout::after,
.lfv5-rich-line,
.lfv5-rich-orb-a,
.lfv5-rich-orb-b,
.lfv5-line,
.lfv5-orb-a,
.lfv5-orb-b {
  content: none !important;
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  transform: none !important;
}

@media (max-width: 760px) {
  .lfv5-showcase-tile-rich,
  .lfv5-showcase-tile {
    min-height: auto !important;
  }
}


/* Leadflow G2-FIX3 fallback: restore showcase card design */
.lfv5-showcase-tile-clean {
  min-height: 285px !important;
  padding: 30px !important;
  border-radius: 30px !important;
  border: 1px solid rgba(20,26,34,.14) !important;
  overflow: hidden !important;
}

.lfv5-rich-tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 20px !important;
}

.lfv5-rich-tags span {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 30px !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.72) !important;
  border: 1px solid rgba(20,26,34,.12) !important;
  font-weight: 800 !important;
  font-size: .82rem !important;
}


/* Leadflow G2-FIX4 fallback: compact showcase sizing */
.lfv5-showcase-tile-clean {
  min-height: 238px !important;
  padding: 24px 26px !important;
  border-radius: 24px !important;
}

.lfv5-showcase-tile-clean .lfv5-rich-topline {
  margin-bottom: 34px !important;
}

.lfv5-showcase-tile-clean .lfv5-rich-icon {
  width: 58px !important;
  height: 58px !important;
  top: 22px !important;
  right: 22px !important;
}

.lfv5-rich-tags {
  margin-top: 15px !important;
}

.lfv5-rich-tags span {
  min-height: 26px !important;
  padding: 0 10px !important;
  font-size: .78rem !important;
}

@media (max-width: 980px) {
  .lfv5-showcase-tile-clean {
    min-height: 0 !important;
    padding: 22px !important;
  }
}


/* Leadflow G2-FIX5 fallback: original Ralf rich-tile structure */
.lfv5-showcase-tile-g2dynamic {
  min-height: 255px !important;
  border-radius: 32px !important;
}

.lfv5-showcase-tile-g2dynamic .lfv5-rich-content {
  min-height: 255px !important;
  padding: 28px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
}

.lfv5-showcase-tile-g2dynamic .lfv5-rich-icon > .lf-icon-badge {
  width: 48px !important;
  height: 48px !important;
  padding: 0 !important;
  display: grid !important;
  place-items: center !important;
  transform: none !important;
  position: relative !important;
}

.lfv5-showcase-tile-g2dynamic .lfv5-rich-icon > .lf-icon-badge svg {
  width: 22px !important;
  height: 22px !important;
  background: transparent !important;
  padding: 0 !important;
}

.lfv5-showcase-tile-g2dynamic .lfv5-rich-chips {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

.lfv5-showcase-tile-g2dynamic .lfv5-rich-chips span {
  width: auto !important;
  flex: 0 0 auto !important;
  white-space: nowrap !important;
}

@media (max-width: 760px) {
  .lfv5-showcase-tile-g2dynamic,
  .lfv5-showcase-tile-g2dynamic .lfv5-rich-content {
    min-height: 230px !important;
  }
}

@media (max-width: 420px) {
  .lfv5-showcase-tile-g2dynamic,
  .lfv5-showcase-tile-g2dynamic .lfv5-rich-content {
    min-height: 218px !important;
  }
}


/* Leadflow G2-FIX6 fallback */
.lfv5-showcase-tile-g2dynamic h3 {
  display: none !important;
}

.lfv5-showcase-tile-g2dynamic,
.lfv5-showcase-tile-g2dynamic .lfv5-rich-content {
  min-height: 226px !important;
}

.lfv5-showcase-tile-g2dynamic .lfv5-rich-content {
  justify-content: flex-start !important;
  padding-top: 104px !important;
}

.lfv5-showcase-tile-g2dynamic .lfv5-rich-icon > .lf-icon-badge {
  position: relative !important;
  inset: auto !important;
  transform: none !important;
  box-shadow: none !important;
}

.lfv5-showcase-tile-g2dynamic .lfv5-rich-chips {
  display: flex !important;
  flex-wrap: wrap !important;
  flex-direction: row !important;
  align-content: flex-start !important;
}

@media (max-width: 760px) {
  .lfv4-hero-card {
    min-height: 0 !important;
  }

  .lfv4-hero-card h2 {
    margin-bottom: 18px !important;
  }

  .lfv5-showcase-tile-g2dynamic,
  .lfv5-showcase-tile-g2dynamic .lfv5-rich-content {
    min-height: 204px !important;
  }

  .lfv5-showcase-tile-g2dynamic .lfv5-rich-content {
    padding-top: 92px !important;
  }
}


/* Leadflow G2-FIX7 fallback: desktop showcase icon size */
@media (min-width: 761px) {
  .lfv5-showcase-tile-g2dynamic .lfv5-rich-icon {
    width: 50px !important;
    height: 50px !important;
    border-radius: 18px !important;
    top: 24px !important;
    right: 24px !important;
  }

  .lfv5-showcase-tile-g2dynamic .lfv5-rich-icon > .lf-icon-badge {
    width: 34px !important;
    height: 34px !important;
    border-radius: 13px !important;
  }

  .lfv5-showcase-tile-g2dynamic .lfv5-rich-icon > .lf-icon-badge svg {
    width: 17px !important;
    height: 17px !important;
  }

  .lfv5-showcase-tile-g2dynamic .lfv5-rich-topline {
    right: 88px !important;
  }
}


/* Leadflow L1-FIX1 fallback: center legal pages */
.lfv4-legal-page-section > .lfv4-container {
  width: min(1040px, calc(100% - 48px)) !important;
  max-width: 1040px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.lfv4-legal-page-card {
  width: 100% !important;
  max-width: 980px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.lfv4-legal-back {
  max-width: 980px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

@media (max-width: 760px) {
  .lfv4-legal-page-section > .lfv4-container {
    width: min(100% - 28px, 980px) !important;
  }

  .lfv4-legal-page-card,
  .lfv4-legal-back {
    max-width: 100% !important;
  }
}


/* Leadflow W2-FIX4 fallback: compact visual summary headline */
.lfv5-visual-layout > *:first-child h2,
.lfv5-visual-section .lfv5-visual-card h2,
.lfv5-visual-section .lfv5-feature-card h2 {
  font-size: clamp(2rem, 4vw, 4.7rem) !important;
  line-height: .98 !important;
  overflow-wrap: anywhere !important;
  hyphens: auto !important;
}

.lfv5-visual-layout > *:first-child p,
.lfv5-visual-section .lfv5-visual-card p,
.lfv5-visual-section .lfv5-feature-card p {
  max-width: 46ch !important;
}


/* Leadflow W2-FIX6 fallback */
.lfv4-benefit-grid > article:nth-of-type(n+5),
.lfv5-showcase-grid > article:nth-of-type(n+5) {
  display: none !important;
}

.lfv5-showcase-tile-g2dynamic p:empty,
.lfv4-benefit p:empty {
  display: none !important;
}


/* Leadflow PH1: Prices + Opening Hours sections */
.lfp1-price-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.lfp1-price-card,
.lfp1-hours-card {
  border: 1px solid color-mix(in srgb, var(--lf-brand-dark, #222832) 16%, transparent);
  border-radius: 26px;
  background:
    radial-gradient(circle at 90% 0%, color-mix(in srgb, var(--lf-brand-primary, #946555) 10%, transparent), transparent 16rem),
    color-mix(in srgb, var(--lf-brand-surface, #f8f2eb) 92%, #fff);
  box-shadow: 0 22px 58px rgba(20, 26, 34, .08);
}

.lfp1-price-card {
  min-height: 170px;
  padding: 28px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 20px;
}

.lfp1-price-card h3 {
  margin: 0 0 10px;
  font-family: var(--lf-font-heading, inherit);
  font-size: clamp(1.25rem, 2vw, 1.75rem);
  line-height: .98;
  color: var(--lf-brand-dark, #222832);
}

.lfp1-price-card p {
  margin: 0;
  color: color-mix(in srgb, var(--lf-brand-dark, #222832) 78%, #fff);
  line-height: 1.55;
}

.lfp1-price-card small,
.lfp1-section-note {
  display: block;
  margin-top: 10px;
  color: color-mix(in srgb, var(--lf-brand-dark, #222832) 58%, #fff);
  font-size: .88rem;
  line-height: 1.45;
}

.lfp1-price-card strong {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--lf-brand-secondary, #a87966), var(--lf-brand-primary, #946555));
  color: #fffaf2;
  font-weight: 850;
  letter-spacing: -.02em;
}

.lfp1-hours-card {
  overflow: hidden;
  padding: 10px;
}

.lfp1-hours-table {
  width: 100%;
  border-collapse: collapse;
}

.lfp1-hours-table tr + tr {
  border-top: 1px solid color-mix(in srgb, var(--lf-brand-dark, #222832) 10%, transparent);
}

.lfp1-hours-table th,
.lfp1-hours-table td {
  padding: 18px 20px;
  text-align: left;
  vertical-align: top;
}

.lfp1-hours-table th {
  width: 34%;
  color: var(--lf-brand-dark, #222832);
  font-weight: 850;
}

.lfp1-hours-table td strong {
  display: block;
  color: color-mix(in srgb, var(--lf-brand-dark, #222832) 86%, var(--lf-brand-primary, #946555));
  font-weight: 750;
}

.lfp1-hours-table td span {
  display: block;
  margin-top: 4px;
  color: color-mix(in srgb, var(--lf-brand-dark, #222832) 60%, #fff);
  font-size: .9rem;
}

.lfp1-hours-card .lfp1-section-note {
  padding: 0 20px 16px;
}

@media (max-width: 980px) {
  .lfp1-price-grid {
    grid-template-columns: 1fr;
  }

  .lfp1-price-card {
    min-height: 0;
  }
}

@media (max-width: 620px) {
  .lfp1-hours-table th,
  .lfp1-hours-table td {
    display: block;
    width: 100%;
    padding: 14px 16px;
  }

  .lfp1-hours-table td {
    padding-top: 0;
  }
}


/* Leadflow PH2: refined manual prices and opening-hours presentation */
.lfp1-hours-section {
  background: transparent;
}

.lfp1-hours-section .lfv4-section-head {
  align-items: start;
}

.lfp1-hours-section .lfv4-section-head > p {
  max-width: 430px;
  margin-top: 74px;
  color: color-mix(in srgb, var(--lf-brand-dark, #222832) 74%, var(--lf-brand-primary, #946555));
}

.lfp1-hours-card {
  max-width: 620px;
  margin-top: -44px;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  overflow: visible !important;
}

.lfp1-hours-table {
  width: 100%;
  border-collapse: separate !important;
  border-spacing: 0 8px !important;
}

.lfp1-hours-table tr,
.lfp1-hours-table tr + tr {
  border: 0 !important;
}

.lfp1-hours-table th,
.lfp1-hours-table td {
  padding: 0 !important;
  vertical-align: baseline;
}

.lfp1-hours-table tr {
  display: grid;
  grid-template-columns: minmax(210px, max-content) minmax(160px, auto);
  gap: 20px;
  align-items: baseline;
}

.lfp1-hours-table th {
  width: auto !important;
  font-weight: 850;
  color: var(--lf-brand-dark, #222832);
  text-align: left;
}

.lfp1-hours-table td strong {
  display: inline-block;
  font-weight: 850;
  color: color-mix(in srgb, var(--lf-brand-dark, #222832) 86%, var(--lf-brand-primary, #946555));
}

.lfp1-hours-table td span,
.lfp1-hours-card .lfp1-section-note {
  display: none !important;
}

.lfp1-prices-section .lfp1-section-note {
  max-width: 760px;
}

@media (max-width: 900px) {
  .lfp1-hours-section .lfv4-section-head > p {
    margin-top: 0;
    max-width: none;
  }

  .lfp1-hours-card {
    margin-top: 0;
    max-width: none;
  }
}

@media (max-width: 620px) {
  .lfp1-hours-table {
    border-spacing: 0 12px !important;
  }

  .lfp1-hours-table tr {
    grid-template-columns: 1fr;
    gap: 2px;
  }
}


/* Leadflow PH3: opening hours as elegant day cards */
.lfp1-hours-section {
  background: transparent !important;
}

.lfp1-hours-section .lfv4-section-head {
  align-items: start !important;
  margin-bottom: 34px !important;
}

.lfp1-hours-section .lfv4-section-head > p {
  max-width: 440px !important;
  margin-top: 72px !important;
  color: color-mix(in srgb, var(--lf-brand-dark, #222832) 74%, var(--lf-brand-primary, #946555)) !important;
}

.lfp1-hours-card {
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.lfp1-hours-table,
.lfp1-hours-table tbody {
  display: block !important;
  width: 100% !important;
  border: 0 !important;
  border-collapse: separate !important;
}

.lfp1-hours-table tbody {
  display: grid !important;
  grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

.lfp1-hours-table tr {
  display: grid !important;
  min-height: 112px !important;
  align-content: space-between !important;
  gap: 12px !important;
  padding: 18px 16px !important;
  border: 0 !important;
  border-radius: 22px !important;
  background:
    radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--lf-brand-primary, #946555) 10%, transparent), transparent 70%),
    color-mix(in srgb, var(--lf-brand-surface, #f8f2eb) 82%, #fff) !important;
  box-shadow: 0 18px 42px rgba(20, 26, 34, .055) !important;
}

.lfp1-hours-table tr + tr {
  border-top: 0 !important;
}

.lfp1-hours-table th,
.lfp1-hours-table td {
  display: block !important;
  width: auto !important;
  padding: 0 !important;
  text-align: left !important;
}

.lfp1-hours-table th {
  color: color-mix(in srgb, var(--lf-brand-dark, #222832) 84%, var(--lf-brand-primary, #946555)) !important;
  font-size: .88rem !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: .02em !important;
}

.lfp1-hours-table td strong {
  display: block !important;
  color: var(--lf-brand-dark, #222832) !important;
  font-size: clamp(1rem, 1.35vw, 1.22rem) !important;
  line-height: 1.08 !important;
  font-weight: 900 !important;
  letter-spacing: -.03em !important;
}

.lfp1-hours-table td span,
.lfp1-hours-card .lfp1-section-note {
  display: none !important;
}

@media (max-width: 1180px) {
  .lfp1-hours-table tbody {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  .lfp1-hours-section .lfv4-section-head > p {
    margin-top: 0 !important;
    max-width: none !important;
  }

  .lfp1-hours-table tbody {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 460px) {
  .lfp1-hours-table tbody {
    grid-template-columns: 1fr !important;
  }
}


/* Leadflow PH4: final list rendering for prices and opening hours */
.lfp4-section-head {
  align-items: flex-start !important;
  margin-bottom: clamp(28px, 4vw, 52px) !important;
}

.lfp4-section-head > p {
  max-width: 430px !important;
  margin-top: clamp(16px, 4.5vw, 76px) !important;
  color: color-mix(in srgb, var(--lf-brand-dark, #222832) 74%, var(--lf-brand-primary, #946555)) !important;
}

/* Prices */
.lfp4-prices-section {
  background: transparent !important;
}

.lfp4-price-list {
  width: min(760px, 100%) !important;
  display: grid !important;
  gap: 10px !important;
}

.lfp4-price-category {
  margin: 22px 0 6px !important;
  font-family: var(--lf-font-heading, inherit) !important;
  font-size: clamp(1.2rem, 2vw, 1.55rem) !important;
  line-height: 1.05 !important;
  color: var(--lf-brand-dark, #222832) !important;
}

.lfp4-price-category:first-child {
  margin-top: 0 !important;
}

.lfp4-price-row {
  display: grid !important;
  grid-template-columns: minmax(180px, max-content) minmax(48px, 1fr) max-content !important;
  gap: 12px !important;
  align-items: baseline !important;
  padding: 10px 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.lfp4-price-title {
  min-width: 0 !important;
}

.lfp4-price-title strong {
  display: block !important;
  font-weight: 850 !important;
  color: var(--lf-brand-dark, #222832) !important;
  line-height: 1.2 !important;
}

.lfp4-price-title span {
  display: block !important;
  margin-top: 4px !important;
  color: color-mix(in srgb, var(--lf-brand-dark, #222832) 62%, #fff) !important;
  font-size: .95rem !important;
  line-height: 1.35 !important;
}

.lfp4-price-dots {
  height: 1px !important;
  border-bottom: 1px dotted color-mix(in srgb, var(--lf-brand-dark, #222832) 24%, transparent) !important;
  transform: translateY(-4px) !important;
}

.lfp4-price-value {
  font-weight: 900 !important;
  color: var(--lf-brand-dark, #222832) !important;
  white-space: nowrap !important;
  letter-spacing: -.02em !important;
}

.lfp4-section-note {
  width: min(760px, 100%) !important;
  margin: 18px 0 0 !important;
  color: color-mix(in srgb, var(--lf-brand-dark, #222832) 58%, #fff) !important;
  font-size: .92rem !important;
  line-height: 1.45 !important;
}

/* Opening hours */
.lfp4-hours-section {
  background: color-mix(in srgb, var(--lf-brand-surface, #f8f2eb) 76%, #fff) !important;
}

.lfp4-hours-grid {
  display: grid !important;
  grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

.lfp4-hours-card {
  min-height: 118px !important;
  padding: 18px 14px !important;
  border-radius: 24px !important;
  border: 1px solid color-mix(in srgb, var(--lf-brand-dark, #222832) 10%, transparent) !important;
  background:
    radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--lf-brand-primary, #946555) 12%, transparent), transparent 72%),
    color-mix(in srgb, var(--lf-brand-surface, #f8f2eb) 88%, #fff) !important;
  box-shadow: 0 18px 46px rgba(20, 26, 34, .06) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  gap: 16px !important;
}

.lfp4-hours-card span {
  font-size: .78rem !important;
  font-weight: 900 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  color: color-mix(in srgb, var(--lf-brand-dark, #222832) 70%, var(--lf-brand-primary, #946555)) !important;
}

.lfp4-hours-card strong {
  display: block !important;
  font-family: var(--lf-font-heading, inherit) !important;
  font-size: clamp(1.05rem, 1.35vw, 1.32rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -.04em !important;
  color: var(--lf-brand-dark, #222832) !important;
}

.lfp4-hours-card.is-closed {
  opacity: .62 !important;
}

.lfp4-hours-card.is-closed strong {
  color: color-mix(in srgb, var(--lf-brand-dark, #222832) 58%, #fff) !important;
}

@media (max-width: 1180px) {
  .lfp4-hours-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  .lfp4-section-head > p {
    margin-top: 0 !important;
    max-width: none !important;
  }

  .lfp4-price-row {
    grid-template-columns: minmax(0, 1fr) max-content !important;
  }

  .lfp4-price-dots {
    display: none !important;
  }

  .lfp4-hours-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 460px) {
  .lfp4-hours-grid {
    grid-template-columns: 1fr !important;
  }
}
