/*
Theme Name: VMLB
Theme URI: https://versicherungen-lothar-becker.de
Author: VMLB / Claude
Description: Modernes, elegantes Block-Theme für Versicherungsmakler Lothar Becker. Markenfarben aus dem Logo (Indigoblau #243090 + Azurblau #24A8D8), warmes Ivory, Fraunces + Inter.
Version: 0.17.0
Requires at least: 6.5
Tested up to: 6.8
Requires PHP: 8.0
Text Domain: vmlb
*/

html { scroll-behavior: smooth; }

/* Elegant touches that theme.json doesn't cover cleanly */
.wp-block-navigation a:hover,
.vmlb-nav a:hover { color: var(--wp--preset--color--brand-2) !important; }

.wp-element-button, .wp-block-button__link { transition: background .2s ease, transform .2s ease, box-shadow .2s ease; }
.wp-element-button:hover, .wp-block-button__link:hover { transform: translateY(-1px); }

/* Hairline + soft shadow utility classes (used by patterns later) */
.vmlb-soft { box-shadow: 0 18px 50px rgba(22,29,84,.07); }
.vmlb-hairline { border: 1px solid var(--wp--preset--color--line); }

/* Refined "pill" badge */
.vmlb-pill {
  display:inline-flex; align-items:center; gap:9px;
  font-size:.8rem; font-weight:600; letter-spacing:.02em;
  padding:8px 16px; border-radius:999px; background:#fff;
  border:1px solid var(--wp--preset--color--line);
  color:var(--wp--preset--color--brand);
}

/* Make the utility-bar links inherit the light color */
.vmlb-utility a { color: inherit; text-decoration: none; }
.vmlb-utility a:hover { color: var(--wp--preset--color--brand-2); }
/* Utility bar: hide address + contact text labels on small screens (icons stay) */
@media (max-width:900px){ .vmlb-util-hideM { display:none !important; } }

/* ---------- Phase 2: sections ---------- */

/* Section kicker (uppercase eyebrow) */
.vmlb-kicker { font-size:.78rem; font-weight:600; color:var(--wp--preset--color--brand-2);
  text-transform:uppercase; letter-spacing:.2em; margin:0 0 .9rem; }

/* Service cards */
.vmlb-card { background:#fff; border:1px solid var(--wp--preset--color--line); border-radius:14px;
  padding:2rem 1.8rem; height:100%; box-sizing:border-box;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease; }
.vmlb-card:hover { transform:translateY(-5px); box-shadow:0 24px 60px rgba(22,29,84,.12); border-color:transparent; }
.vmlb-ic { width:54px; height:54px; border-radius:14px; background:var(--wp--preset--color--ivory-2);
  border:1px solid var(--wp--preset--color--line); display:grid; place-items:center;
  color:var(--wp--preset--color--brand); margin-bottom:1.2rem; transition:.22s; }
.vmlb-card:hover .vmlb-ic { background:linear-gradient(142deg,var(--wp--preset--color--brand),var(--wp--preset--color--brand-2));
  border-color:transparent; color:#fff; }
.vmlb-more { font-weight:600; font-size:.9rem; color:var(--wp--preset--color--brand-2);
  display:inline-flex; align-items:center; gap:.4em; margin:1rem 0 0; }
.vmlb-card:hover .vmlb-more { gap:.7em; }

/* Steps */
.vmlb-stepnum { width:46px; height:46px; border-radius:50%; background:#fff;
  border:1px solid var(--wp--preset--color--line); display:grid; place-items:center;
  font-family:'Fraunces',Georgia,serif; font-weight:600; color:var(--wp--preset--color--brand);
  box-shadow:0 18px 50px rgba(22,29,84,.07); margin-bottom:1.1rem; }

/* Stats + features on blue band */
.vmlb-stat { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12);
  border-radius:14px; padding:1.7rem 1.5rem; height:100%; box-sizing:border-box; }
.vmlb-statnum { font-family:'Fraunces',Georgia,serif; font-size:2.7rem; font-weight:500; color:#fff; line-height:1; }
.vmlb-statnum em { font-style:normal; color:var(--wp--preset--color--brand-2); }
.vmlb-statlabel { color:#c4cdf0; font-size:.85rem; margin-top:.55rem; }
.vmlb-feat { display:flex; gap:1rem; align-items:flex-start; margin-bottom:1.4rem; }
.vmlb-featic { width:42px; height:42px; border-radius:11px; background:rgba(36,168,216,.18);
  border:1px solid rgba(36,168,216,.30); color:var(--wp--preset--color--brand-2);
  display:grid; place-items:center; flex:0 0 auto; }
.vmlb-feat b { color:#fff; display:block; font-size:1rem; margin-bottom:.15rem; }
.vmlb-feat span { color:#c4cdf0; font-size:.9rem; line-height:1.6; }

/* Reviews */
.vmlb-rev { background:#fff; border:1px solid var(--wp--preset--color--line); border-radius:14px;
  padding:1.8rem; box-shadow:0 18px 50px rgba(22,29,84,.07); height:100%; box-sizing:border-box; }
.vmlb-stars { color:var(--wp--preset--color--gold); display:inline-flex; gap:3px; }
.vmlb-quote { font-family:'Fraunces',Georgia,serif; font-size:1.05rem; line-height:1.7;
  color:var(--wp--preset--color--ink); margin:.9rem 0 0; }
.vmlb-who { display:flex; align-items:center; gap:.8rem; margin-top:1.3rem; }
/* Avatar chip: light circle + brand initials (higher specificity so .vmlb-who span
   below doesn't grey out the initials — that was the low-contrast bug). */
.vmlb-who span.vmlb-av { width:42px; height:42px; border-radius:50%;
  background:var(--wp--preset--color--ivory-2); border:1px solid var(--wp--preset--color--line);
  color:var(--wp--preset--color--brand); display:grid; place-items:center; font-weight:700;
  font-size:.85rem; letter-spacing:.02em; flex:0 0 auto;
  box-shadow:0 6px 16px rgba(22,29,84,.08); }
.vmlb-who b { color:var(--wp--preset--color--brand); display:block; font-size:.92rem; }
.vmlb-who span { color:var(--wp--preset--color--slate); font-size:.85rem; }

/* Social icons (footer, on deep blue) */
.vmlb-social { display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1.4rem; }
.vmlb-social a { width:38px; height:38px; border-radius:10px; display:grid; place-items:center;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.14);
  color:#c4cdf0; transition:transform .18s ease, color .18s ease, border-color .18s ease; }
.vmlb-social a:hover { color:var(--wp--preset--color--brand-2);
  border-color:rgba(36,168,216,.55); transform:translateY(-2px); }

/* Brand logo — header (on white bar) + footer (white tile on dark) */
.vmlb-brand { display:inline-flex; align-items:center; gap:.65rem; text-decoration:none; }
.vmlb-brand img { height:44px; width:auto; display:block; }
.vmlb-brand-txt { font-family:'Fraunces',Georgia,serif; font-weight:600; font-size:1.02rem;
  line-height:1.08; color:var(--wp--preset--color--brand); }
.vmlb-brand-suffix { font-weight:500; font-size:0.72em; color:var(--wp--preset--color--slate); white-space:nowrap; }
.vmlb-flogo { display:inline-flex; background:#fff; border-radius:14px; padding:.7rem;
  margin-bottom:1.15rem; line-height:0; box-shadow:0 12px 32px rgba(0,0,0,.20); }
.vmlb-flogo img { width:56px; height:auto; display:block; border-radius:4px; }

/* Clickable static map (OSM image → Google Maps directions; no runtime 3rd-party load) */
.vmlb-mapimg { position:relative; display:block; border-radius:14px; overflow:hidden;
  border:1px solid var(--wp--preset--color--line); box-shadow:0 12px 32px rgba(22,29,84,.10); line-height:0; }
.vmlb-mapimg img { width:100%; height:auto; display:block; transition:transform .35s ease; }
.vmlb-mapimg:hover img { transform:scale(1.04); }
.vmlb-mapimg-hint { position:absolute; right:12px; bottom:12px; z-index:2;
  background:var(--wp--preset--color--brand); color:#fff; font-size:.78rem; font-weight:600;
  padding:.5rem .85rem; border-radius:999px; line-height:1; display:inline-flex; align-items:center; gap:.4em;
  box-shadow:0 6px 18px rgba(22,29,84,.32); }
.vmlb-mapimg-hint::before { content:""; width:13px; height:13px; flex:0 0 auto;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s-7-5-7-11a7 7 0 0 1 14 0c0 6-7 11-7 11z'/%3E%3Ccircle cx='12' cy='10' r='2.5'/%3E%3C/svg%3E"); }

/* ---------- Phase 3: inner pages ---------- */

/* Breadcrumb */
.vmlb-crumb { font-size:.82rem; color:var(--wp--preset--color--slate); margin:0 0 .9rem; }
.vmlb-crumb a { color:var(--wp--preset--color--brand-2); text-decoration:none; }
.vmlb-crumb a:hover { text-decoration:underline; }

/* Benefits checklist + card */
.vmlb-benefitcard { background:#fff; border:1px solid var(--wp--preset--color--line);
  border-radius:14px; padding:1.9rem; box-shadow:0 18px 50px rgba(22,29,84,.07); }
.vmlb-benefits { list-style:none; margin:0; padding:0; display:grid; gap:1rem; }
.vmlb-benefits li { display:flex; gap:.7em; align-items:flex-start; font-size:.97rem; color:var(--wp--preset--color--ink); }
.vmlb-benefits .ck { color:var(--wp--preset--color--brand-2); flex:0 0 auto; margin-top:3px; }

/* Vergleichsrechner embed placeholder */
.vmlb-calc { background:#fff; border:1.5px dashed #c1c8e0; border-radius:16px;
  padding:2.6rem 2rem; text-align:center; }
.vmlb-calc .badge { display:inline-block; font-size:.72rem; font-weight:600; letter-spacing:.12em;
  text-transform:uppercase; color:var(--wp--preset--color--brand-2);
  background:var(--wp--preset--color--ivory-2); padding:.35rem .8rem; border-radius:999px; margin-bottom:1rem; }

/* FAQ accordion */
.vmlb-faq details { border:1px solid var(--wp--preset--color--line); border-radius:12px;
  background:#fff; padding:0 1.3rem; margin-bottom:.8rem; }
.vmlb-faq summary { cursor:pointer; padding:1.15rem 0; font-weight:600;
  color:var(--wp--preset--color--brand); list-style:none; display:flex;
  justify-content:space-between; align-items:center; gap:1rem; }
.vmlb-faq summary::-webkit-details-marker { display:none; }
.vmlb-faq summary::after { content:"+"; font-size:1.4rem; font-weight:400;
  color:var(--wp--preset--color--brand-2); line-height:1; }
.vmlb-faq details[open] summary::after { content:"\2212"; }
.vmlb-faq details > p { padding:0 0 1.2rem; margin:0; color:var(--wp--preset--color--slate);
  font-size:.95rem; line-height:1.7; }

/* Contact info rows + form + map */
.vmlb-info { display:grid; gap:1.2rem; }
.vmlb-info .row { display:flex; gap:.95rem; align-items:flex-start; }
.vmlb-info .ic { width:44px; height:44px; border-radius:12px; background:var(--wp--preset--color--ivory-2);
  border:1px solid var(--wp--preset--color--line); color:var(--wp--preset--color--brand);
  display:grid; place-items:center; flex:0 0 auto; }
.vmlb-info b { display:block; color:var(--wp--preset--color--ink); font-size:.95rem; }
.vmlb-info span, .vmlb-info a { color:var(--wp--preset--color--slate); font-size:.93rem; text-decoration:none; }
.vmlb-info a:hover { color:var(--wp--preset--color--brand-2); }
.vmlb-form { background:#fff; border:1px solid var(--wp--preset--color--line); border-radius:16px;
  padding:2rem; box-shadow:0 18px 50px rgba(22,29,84,.07); }
.vmlb-form label { display:block; font-size:.84rem; font-weight:600;
  color:var(--wp--preset--color--ink); margin:0 0 .35rem; }
.vmlb-field { width:100%; padding:.8rem .9rem; border:1px solid var(--wp--preset--color--line);
  border-radius:9px; font:inherit; background:var(--wp--preset--color--ivory);
  margin-bottom:1.1rem; box-sizing:border-box; color:var(--wp--preset--color--ink); }
.vmlb-field:focus { outline:2px solid var(--wp--preset--color--brand-2); border-color:transparent; }

/* Header "Versicherungen" mega-menu (hover + keyboard focus, no JS) */
.vmlb-mega { position:relative; display:inline-flex; align-items:center; }
.vmlb-mega-toggle { display:inline-flex; align-items:center; gap:.3em;
  font-size:.97rem; font-weight:500; color:inherit; text-decoration:none; }
.vmlb-mega-toggle svg { opacity:.65; transition:transform .2s ease; }
.vmlb-mega:hover .vmlb-mega-toggle svg, .vmlb-mega:focus-within .vmlb-mega-toggle svg { transform:rotate(180deg); }
/* Popover anchored to the toggle's right edge so it can't overflow the viewport;
   transparent top bridge keeps hover alive across the gap to the panel */
.vmlb-mega-pop { position:absolute; top:100%; right:0; padding-top:14px; z-index:60;
  opacity:0; visibility:hidden; pointer-events:none; transition:opacity .18s ease; }
.vmlb-mega:hover .vmlb-mega-pop, .vmlb-mega:focus-within .vmlb-mega-pop {
  opacity:1; visibility:visible; pointer-events:auto; }
.vmlb-mega-panel { background:#fff; border:1px solid var(--wp--preset--color--line);
  border-radius:16px; box-shadow:0 24px 60px rgba(22,29,84,.14); padding:1.5rem 1.7rem;
  display:grid; grid-template-columns:repeat(3, minmax(170px, 1fr)); gap:1.5rem 2.2rem;
  width:max-content; max-width:min(760px, 92vw); }
.vmlb-mega-col { display:flex; flex-direction:column; gap:.3rem; }
.vmlb-mega-head { font-family:'Fraunces',Georgia,serif; font-size:1.05rem; font-weight:500;
  color:var(--wp--preset--color--brand); text-decoration:none; }
.vmlb-mega-sub { font-size:.85rem; line-height:1.55; color:var(--wp--preset--color--slate); }
.vmlb-mega-sub a { color:var(--wp--preset--color--brand); font-weight:500; text-decoration:none; }
/* Mobile nav toggles — visually hidden on desktop, activated in the max-width:980px block
   at the end of this file. Checkboxes stay in the a11y tree (sr-only, not display:none). */
.vmlb-navcheck, .vmlb-megacheck { position:absolute; width:1px; height:1px; opacity:0; margin:-1px; pointer-events:none; }
.vmlb-burger, .vmlb-mega-tap { display:none; }

/* Comparison tables (AEO-friendly, used on spoke/product pages) */
.vmlb-table { width:100%; border-collapse:collapse; margin:.4rem 0 0; font-size:.93rem;
  background:#fff; border:1px solid var(--wp--preset--color--line); border-radius:12px; overflow:hidden; }
.vmlb-table th, .vmlb-table td { padding:.8rem .95rem; text-align:left;
  border-bottom:1px solid var(--wp--preset--color--line); vertical-align:top; }
.vmlb-table thead th { background:var(--wp--preset--color--ivory-2); color:var(--wp--preset--color--ink);
  font-weight:600; font-size:.8rem; letter-spacing:.02em; text-transform:uppercase; }
.vmlb-table tbody tr:last-child td { border-bottom:0; }
.vmlb-table td:first-child { font-weight:500; color:var(--wp--preset--color--ink); }
.vmlb-table td { color:var(--wp--preset--color--slate); line-height:1.55; }
/* Scroll wrapper: on narrow phones the comparison table keeps a readable width and
   scrolls horizontally inside its own box instead of blowing out the page width. */
.vmlb-tablewrap { max-width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch; }
@media (max-width:560px) { .vmlb-tablewrap > .vmlb-table { min-width:30rem; } }

/* Author byline (E-E-A-T): "Beraten von … · Stand: …" under the H1. Icon via ::before so the
   block markup stays a plain, editor-safe paragraph (no Custom HTML). */
.vmlb-byline { display:flex; align-items:center; gap:.5em; flex-wrap:wrap;
  color:var(--wp--preset--color--slate); letter-spacing:.005em; }
.vmlb-byline strong { color:var(--wp--preset--color--brand); font-weight:600; }
.vmlb-byline::before { content:""; width:16px; height:16px; flex:0 0 auto;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='16'%20height='16'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23243090'%20stroke-width='1.8'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Ccircle%20cx='12'%20cy='8'%20r='4'/%3E%3Cpath%20d='M4%2021c0-4%204-6%208-6s8%202%208%206'/%3E%3C/svg%3E"); }

/* ---------- Mobile navigation (≤980px): hamburger drawer + inline mega accordion, no JS ---------- */
@media (max-width:980px){
  .vmlb-headbar { flex-wrap:wrap; }

  /* Hamburger button (the label drives the hidden checkbox) */
  .vmlb-burger { display:flex !important; flex-direction:column; justify-content:center; gap:5px;
    width:46px; height:42px; margin-left:auto; padding:0 11px; cursor:pointer;
    border:1px solid var(--wp--preset--color--line); border-radius:10px; background:#fff; box-sizing:border-box; }
  .vmlb-burger span { display:block; width:100%; height:2px; border-radius:2px;
    background:var(--wp--preset--color--brand); transition:transform .22s ease, opacity .18s ease; }
  .vmlb-navcheck:checked ~ .vmlb-burger span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .vmlb-navcheck:checked ~ .vmlb-burger span:nth-child(2){ opacity:0; }
  .vmlb-navcheck:checked ~ .vmlb-burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

  /* Drawer: hidden until the checkbox is on (!important beats WordPress' equal-specificity
     .wp-block-group-is-layout-flex{display:flex} on the same element) */
  .vmlb-nav { display:none !important; order:5; flex-basis:100%; width:100%; flex-direction:column;
    align-items:stretch; gap:0 !important; margin-top:.9rem; padding-top:.2rem;
    border-top:1px solid var(--wp--preset--color--line); }
  .vmlb-navcheck:checked ~ .vmlb-nav { display:flex !important; }

  /* Top-level links: full width, comfortable tap targets */
  .vmlb-nav > p { margin:0 !important; width:100%; border-bottom:1px solid var(--wp--preset--color--line); }
  .vmlb-nav > p a { display:block; padding:.9rem .2rem; font-size:1rem; }
  .vmlb-nav .wp-block-buttons { margin-top:1.1rem; }
  .vmlb-nav .wp-block-button { width:100%; }
  .vmlb-nav .wp-block-button__link { display:block; text-align:center; }

  /* "Versicherungen" mega becomes an inline accordion */
  .vmlb-mega { display:block; position:relative; width:100%;
    border-bottom:1px solid var(--wp--preset--color--line); }
  .vmlb-mega-toggle { padding:.9rem .2rem; font-size:1rem; justify-content:space-between; }
  .vmlb-mega-toggle svg { opacity:.85; }
  .vmlb-mega-tap { display:block; position:absolute; top:0; left:0; right:0; height:3rem; z-index:2; cursor:pointer; }
  .vmlb-mega-pop { position:static; opacity:1; visibility:visible; pointer-events:auto;
    padding-top:0; display:none; }
  .vmlb-megacheck:checked ~ .vmlb-mega-pop { display:block; }
  .vmlb-megacheck:checked ~ .vmlb-mega-toggle svg { transform:rotate(180deg); }
  .vmlb-mega-panel { display:block; border:0; box-shadow:none; border-radius:0;
    padding:.1rem 0 .8rem .8rem; width:auto; max-width:none; }
  .vmlb-mega-col { padding:.5rem 0; }
  .vmlb-mega-head { font-size:1rem; }
}

/* ---------- Vergleichsrechner (click-to-load cards) ---------- */
.vmlb-rk-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(270px, 1fr)); gap:1.1rem; align-items:stretch; }
.vmlb-rk { background:#fff; border:1px solid var(--wp--preset--color--line); border-radius:14px;
  padding:1.4rem 1.4rem 1.5rem; display:flex; flex-direction:column; gap:1rem;
  box-shadow:0 18px 50px rgba(22,29,84,.06); }
.vmlb-rk-body { display:flex; flex-direction:column; gap:.3rem; }
.vmlb-rk-prov { font-size:.72rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:var(--wp--preset--color--brand-2); }
.vmlb-rk-title { font-family:'Fraunces',Georgia,serif; font-size:1.12rem; line-height:1.25;
  color:var(--wp--preset--color--brand); }
.vmlb-rk-cta { margin-top:auto; display:flex; flex-direction:column; gap:.6rem; align-items:flex-start; }
.vmlb-rk-btn { display:inline-flex; align-items:center; gap:.5em; border:0; cursor:pointer; font-weight:600;
  color:#fff; background:var(--wp--preset--color--brand); padding:.7rem 1.15rem; border-radius:999px;
  font-size:.92rem; text-decoration:none; }
.vmlb-rk-btn:hover { background:var(--wp--preset--color--brand-2); color:#fff; }
.vmlb-rk-note { font-size:.78rem; color:var(--wp--preset--color--slate); line-height:1.5; }

/* Sticky category nav on the Vergleichsrechner page */
.vmlb-rk-nav { display:flex; flex-wrap:wrap; gap:.5rem; position:sticky; top:0; z-index:5;
  background:var(--wp--preset--color--ivory); padding:.9rem 0; margin:0 0 1.5rem; }
.vmlb-rk-nav a { font-size:.86rem; font-weight:500; text-decoration:none; color:var(--wp--preset--color--brand);
  background:#fff; border:1px solid var(--wp--preset--color--line); border-radius:999px; padding:.4rem .9rem; }
.vmlb-rk-nav a:hover { border-color:var(--wp--preset--color--brand-2); color:var(--wp--preset--color--brand-2); }
.vmlb-rk-cattitle { font-family:'Fraunces',Georgia,serif; font-weight:500; font-size:1.5rem;
  color:var(--wp--preset--color--brand); scroll-margin-top:5rem; margin:2.6rem 0 1.1rem; }
.vmlb-rk-cattitle:first-of-type { margin-top:0; }

/* Legal acceptance gate */
.vmlb-rk-consent { background:#fff; border:1px solid var(--wp--preset--color--line);
  border-left:4px solid var(--wp--preset--color--brand-2); border-radius:12px;
  padding:1.2rem 1.3rem; margin:0 0 1.6rem; }
.vmlb-rk-consent.is-error { border-color:#c0392b; border-left-color:#c0392b; background:#fdf3f2; }
.vmlb-rk-consent-note { font-size:.9rem; line-height:1.6; color:var(--wp--preset--color--slate); margin:0 0 .9rem; }
.vmlb-rk-consent-check { display:flex; gap:.65em; align-items:flex-start; cursor:pointer;
  font-size:.9rem; line-height:1.6; color:var(--wp--preset--color--ink); }
.vmlb-rk-consent-check input { margin:.15em 0 0; flex:0 0 auto; width:18px; height:18px; accent-color:var(--wp--preset--color--brand); }
.vmlb-rk-consent-check a { color:var(--wp--preset--color--brand-2); }
/* Locked state: dim the calculators until the gate is accepted */
.vmlb-rk-zone:not(.is-accepted) .vmlb-rk-nav { opacity:.45; pointer-events:none; }
.vmlb-rk-zone:not(.is-accepted) .vmlb-rk-grid { opacity:.5; }
.vmlb-rk-zone:not(.is-accepted) .vmlb-rk-cattitle { opacity:.5; }


/* Hero "Wofür brauchen Sie Schutz?" — clickable category tiles */
.vmlb-hero-tile { display:block; text-align:center; text-decoration:none;
  border:1px solid rgba(255,255,255,0.16); border-radius:12px; color:#eaf6fc;
  padding:0.9rem 0; font-size:0.8rem; font-weight:600;
  transition:background .18s ease, border-color .18s ease, transform .18s ease; }
.vmlb-hero-tile:hover, .vmlb-hero-tile:focus-visible {
  background:rgba(255,255,255,0.12); border-color:rgba(255,255,255,0.55);
  color:#fff; transform:translateY(-1px); outline:none; }

/* Contact Form 7 — an das VMLB-Formulardesign angeglichen */
.vmlb-form-title { font-family:'Fraunces',Georgia,serif; font-size:1.25rem; color:var(--wp--preset--color--brand); margin:0 0 1.3rem; }
.vmlb-form .wpcf7-submit { width:100%; justify-content:center; border:0; cursor:pointer; font-weight:600; margin-top:.3rem; }
.vmlb-form-consent { display:flex; gap:.6em; align-items:flex-start; font-size:.84rem;
  line-height:1.55; color:var(--wp--preset--color--slate); margin:.2rem 0 1.1rem; }
.vmlb-form-consent .wpcf7-list-item { margin:0; }
.vmlb-form-consent input[type=checkbox] { margin:.15em 0 0; flex:0 0 auto; width:18px; height:18px; accent-color:var(--wp--preset--color--brand); }
.vmlb-form-consent a { color:var(--wp--preset--color--brand-2); }
.vmlb-form .wpcf7-response-output { border-radius:9px; margin:.8rem 0 0; padding:.7rem .9rem; font-size:.86rem; }
.vmlb-form .wpcf7-not-valid-tip { color:#c0392b; font-size:.78rem; margin:-.7rem 0 1rem; }
.vmlb-form .wpcf7-spinner { margin:.6rem auto 0; display:block; }
