:root {
  --lc-black: #050505;
  --lc-black-2: #111318;
  --lc-navy: #07151f;
  --lc-navy-2: #0c2736;
  --lc-blue: #008cc3;
  --lc-blue-2: #006f9f;
  --lc-cyan: #45c4f3;
  --lc-mint: #effbff;
  --lc-ink: #080a0f;
  --lc-text: #252a33;
  --lc-muted: #5d6675;
  --lc-line: #d9e9f0;
  --lc-bg: #f5fbfd;
  --lc-white: #ffffff;
  --lc-radius-sm: 14px;
  --lc-radius: 24px;
  --lc-radius-lg: 34px;
  --lc-shadow: 0 24px 70px rgba(0, 61, 90, .14);
  --lc-shadow-soft: 0 14px 34px rgba(0, 61, 90, .08);
  --lc-container: min(1180px, calc(100vw - 40px));
  --lc-transition: 180ms ease;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--lc-text);
  background: var(--lc-white);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 17px;
  line-height: 1.65;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; }
a { color: var(--lc-blue); text-decoration-thickness: .08em; text-underline-offset: .18em; }
a:hover { color: var(--lc-navy); }

h1, h2, h3, h4, h5, h6 {
  margin: 0 0 .65em;
  color: var(--lc-ink);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -.03em;
}
h1 { font-size: clamp(2.55rem, 5vw, 5rem); }
h2 { font-size: clamp(2rem, 3vw, 3.35rem); }
h3 { font-size: clamp(1.35rem, 2vw, 1.75rem); }
h4 { font-size: 1.12rem; }
p { margin: 0 0 1.2rem; }
strong { color: var(--lc-ink); }

.lc-container,
.site-header__inner,
.site-footer__inner,
.lc-content > *:not(.alignfull),
.lc-content .wp-block-group:not(.alignfull) > .wp-block-group__inner-container {
  width: var(--lc-container);
  max-width: var(--lc-container);
  margin-inline: auto;
}
.lc-content .alignwide { width: var(--lc-container); max-width: var(--lc-container); margin-left: auto; margin-right: auto; }
.lc-content .alignfull { width: 100%; max-width: none; }

.screen-reader-text {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

.skip-link:focus {
  position: fixed;
  z-index: 9999;
  left: 1rem;
  top: 1rem;
  background: #fff;
  color: #000;
  padding: .75rem 1rem;
  border-radius: 8px;
  box-shadow: var(--lc-shadow);
}

/* Header */

.site-header .brand { color: #fff; }
.site-header .primary-menu a { color: rgba(255,255,255,.90); }
.site-header .primary-menu a:hover,
.site-header .primary-menu .current-menu-item > a,
.site-header .primary-menu .current-menu-ancestor > a { background: rgba(0,109,255,.20); color: #fff; }
.site-header .primary-menu .sub-menu a { color: var(--lc-ink); }
.site-header .primary-menu .sub-menu a:hover { color: var(--lc-blue); background: #edf4ff; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(5,5,5,.92);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  min-height: 82px;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: .85rem;
  color: var(--lc-black);
  text-decoration: none;
}
.brand__mark {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: var(--lc-white);
  color: var(--lc-black);
  border: 2px solid var(--lc-blue);
  font-weight: 900;
  letter-spacing: -.05em;
  box-shadow: 0 12px 30px rgba(0,109,255,.32);
}
.brand__text { display: grid; line-height: 1.05; }
.brand__name { color: #fff; font-weight: 900; letter-spacing: -.03em; font-size: 1.05rem; }
.brand__claim { color: rgba(255,255,255,.68); font-size: .8rem; margin-top: .25rem; }

.primary-nav { display: flex; align-items: center; gap: 1.1rem; }
.primary-menu,
.primary-menu ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.primary-menu {
  display: flex;
  align-items: center;
  gap: .2rem;
}
.primary-menu li { position: relative; }
.primary-menu a {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .7rem .78rem;
  border-radius: 999px;
  color: rgba(255,255,255,.90);
  text-decoration: none;
  font-size: .96rem;
  font-weight: 750;
}
.primary-menu a:hover,
.primary-menu .current-menu-item > a,
.primary-menu .current-menu-ancestor > a {
  background: rgba(0,109,255,.18);
  color: #fff;
}
.primary-menu .sub-menu {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  min-width: 270px;
  display: grid;
  gap: .22rem;
  padding: .65rem;
  border-radius: 18px;
  background: var(--lc-white);
  border: 1px solid var(--lc-line);
  box-shadow: var(--lc-shadow-soft);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity var(--lc-transition), transform var(--lc-transition), visibility var(--lc-transition);
}
.primary-menu li:hover > .sub-menu,
.primary-menu li:focus-within > .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}
.primary-menu .sub-menu a {
  display: flex;
  padding: .72rem .85rem;
  border-radius: 12px;
  white-space: normal;
}
.header-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: .78rem 1.05rem;
  border-radius: 999px;
  background: var(--lc-blue);
  color: #fff;
  text-decoration: none;
  font-weight: 850;
  box-shadow: 0 14px 28px rgba(6,18,38,.18);
}
.header-cta:hover { background: #fff; color: var(--lc-black); }
.nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 46px; height: 46px;
  border: 1px solid var(--lc-line);
  border-radius: 14px;
  background: #fff;
  color: var(--lc-black);
}
.nav-toggle span,
.nav-toggle span::before,
.nav-toggle span::after {
  display: block;
  width: 20px; height: 2px;
  background: currentColor;
  position: relative;
  content: "";
}
.nav-toggle span::before { position: absolute; top: -7px; }
.nav-toggle span::after { position: absolute; top: 7px; }

/* Generic content */
.lc-content { overflow: hidden; }
.entry-header {
  padding: clamp(3rem, 8vw, 7rem) 0 2rem;
  background: linear-gradient(180deg, #f7fbff 0%, #fff 100%);
}
.entry-title { max-width: 900px; }
.entry-content > .wp-block-group,
.entry-content > .wp-block-columns,
.entry-content > .wp-block-cover,
.entry-content > .wp-block-media-text,
.lc-section {
  margin-block: clamp(3rem, 7vw, 6.5rem);
}
.entry-content > *:first-child { margin-top: 0; }
.entry-content > *:last-child { margin-bottom: 0; }

/* Buttons */
.wp-block-button__link,
.lc-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: .92rem 1.18rem;
  border-radius: 999px;
  background: var(--lc-blue);
  color: #fff !important;
  text-decoration: none;
  font-weight: 850;
  box-shadow: 0 15px 30px rgba(23,103,194,.2);
  transition: transform var(--lc-transition), box-shadow var(--lc-transition), background var(--lc-transition);
}
.wp-block-button__link:hover,
.lc-button:hover {
  transform: translateY(-1px);
  background: var(--lc-navy);
  box-shadow: 0 20px 40px rgba(6,18,38,.18);
}
.wp-block-button.is-style-outline .wp-block-button__link,
.lc-button--ghost {
  background: #fff;
  color: var(--lc-navy) !important;
  border: 1px solid var(--lc-line);
  box-shadow: none;
}
.wp-block-buttons { gap: .8rem; }

/* Hero */
.lc-hero {
  position: relative;
  padding: clamp(3rem, 7vw, 7rem) 0 clamp(3rem, 6vw, 5rem);
  background:
    radial-gradient(circle at 80% 20%, rgba(0,109,255,.20), transparent 35%),
    linear-gradient(135deg, #f6fbff 0%, #fff 55%, #eef8ff 100%);
}
.lc-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(23,103,194,.06) 1px, transparent 1px), linear-gradient(90deg, rgba(23,103,194,.06) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(180deg, #000, transparent 74%);
  pointer-events: none;
}
.lc-hero .wp-block-columns {
  position: relative;
  z-index: 1;
  align-items: center !important;
  gap: clamp(2rem, 5vw, 5rem);
  margin: 0 auto;
  width: var(--lc-container);
}
.lc-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin: 0 0 1rem;
  padding: .45rem .75rem;
  border-radius: 999px;
  background: rgba(23,103,194,.09);
  color: var(--lc-blue);
  font-size: .9rem;
  font-weight: 850;
  letter-spacing: .01em;
}
.lc-lead { font-size: clamp(1.08rem, 2vw, 1.32rem); color: #42526a; max-width: 64ch; }
.lc-hero-card {
  position: relative;
  border-radius: var(--lc-radius-lg);
  overflow: hidden;
  box-shadow: var(--lc-shadow);
  background: var(--lc-black);
  min-height: 520px;
}
.lc-hero-card img,
.lc-hero-card .wp-block-image img {
  width: 100%;
  height: 100%;
  min-height: 520px;
  object-fit: cover;
  display: block;
}
.lc-hero-card::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 38%;
  background: linear-gradient(180deg, transparent, rgba(6,18,38,.66));
}
.lc-hero-badge {
  position: absolute;
  z-index: 2;
  left: 24px;
  bottom: 24px;
  width: calc(100% - 48px);
  padding: 1rem 1.1rem;
  border-radius: 18px;
  color: #fff;
  background: rgba(6,18,38,.78);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(10px);
  font-size: .95rem;
}
.lc-hero-badge strong { color: #fff; display: block; }

/* Sections */
.lc-soft {
  padding: clamp(3rem, 6vw, 6rem) 0;
  background: var(--lc-bg);
}
.lc-dark {
  padding: clamp(3rem, 6vw, 6rem) 0;
  background: radial-gradient(circle at 82% 0%, rgba(0,109,255,.28), transparent 34%), linear-gradient(135deg, #050505 0%, #10141c 100%);
  color: #dbe7ff;
}
.lc-dark h2,
.lc-dark h3,
.lc-dark h4,
.lc-dark strong { color: #fff; }
.lc-dark a { color: #9eeaff; }
.lc-section-head { max-width: 820px; margin: 0 auto 2.4rem; text-align: center; }
.lc-section-head p { font-size: 1.1rem; color: var(--lc-muted); }
.lc-dark .lc-section-head p { color: #b8c7dc; }

.lc-card-grid,
.lc-reference-grid,
.lc-gallery-grid {
  display: grid;
  gap: 1.15rem;
}
.lc-card-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.lc-reference-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.lc-gallery-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }

.lc-card,
.lc-reference,
.lc-process-card,
.lc-contact-card,
.lc-page-card {
  padding: clamp(1.25rem, 2.2vw, 1.7rem);
  border-radius: var(--lc-radius);
  background: var(--lc-white);
  border: 1px solid var(--lc-line);
  box-shadow: var(--lc-shadow-soft);
}
.lc-card { min-height: 270px; border-top: 4px solid var(--lc-blue); }
.lc-card__icon {
  width: 54px; height: 54px;
  display: grid; place-items: center;
  margin-bottom: 1.1rem;
  border-radius: 18px;
  background: linear-gradient(135deg, #f5f8ff, #e7f0ff);
  color: var(--lc-blue);
  font-size: 1.45rem;
}
.lc-card p,
.lc-reference p { color: var(--lc-muted); }
.lc-card a { font-weight: 850; text-decoration: none; }

.lc-image-card {
  position: relative;
  overflow: hidden;
  border-radius: var(--lc-radius);
  min-height: 320px;
  box-shadow: var(--lc-shadow-soft);
  background: #dbe5f1;
}
.lc-image-card img {
  display: block;
  width: 100%; height: 100%; min-height: 320px;
  object-fit: cover;
  transition: transform 500ms ease;
}
.lc-image-card:hover img { transform: scale(1.035); }
.lc-image-card__label {
  position: absolute;
  left: 18px; right: 18px; bottom: 18px;
  padding: .9rem 1rem;
  border-radius: 16px;
  background: rgba(6,18,38,.78);
  color: #fff;
  backdrop-filter: blur(10px);
  font-weight: 850;
}

.lc-proof-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  margin-top: 2rem;
}
.lc-pill {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: .55rem .88rem;
  border-radius: 999px;
  background: var(--lc-white);
  border: 1px solid var(--lc-line);
  color: var(--lc-ink);
  font-weight: 850;
  font-size: .95rem;
  box-shadow: 0 8px 22px rgba(4,18,38,.05);
}
.lc-dark .lc-pill {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.16);
  color: #fff;
}

.lc-metric-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 2rem;
}
.lc-metric {
  padding: 1.4rem;
  border-radius: var(--lc-radius);
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.16);
}
.lc-metric strong { display: block; font-size: 2rem; line-height: 1; margin-bottom: .35rem; }
.lc-metric span { color: #b8c7dc; }

.lc-process {
  counter-reset: step;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}
.lc-process-card { position: relative; padding-top: 4rem; }
.lc-process-card::before {
  counter-increment: step;
  content: "0" counter(step);
  position: absolute;
  top: 1.35rem; left: 1.35rem;
  width: 46px; height: 46px;
  border-radius: 15px;
  display: grid;
  place-items: center;
  background: var(--lc-blue);
  color: #fff;
  font-weight: 900;
}

.lc-reference {
  display: flex;
  align-items: center;
  min-height: 110px;
  font-weight: 900;
  font-size: 1.1rem;
  color: var(--lc-ink);
}
.lc-reference::before {
  content: "";
  width: 11px; height: 46px;
  border-radius: 999px;
  margin-right: 1rem;
  background: linear-gradient(180deg, var(--lc-blue), var(--lc-black));
}


.lc-reference span { display: grid; gap: .18rem; }
.lc-reference small { color: var(--lc-muted); font-weight: 700; font-size: .88rem; line-height: 1.35; }
.lc-dark .lc-reference { background: rgba(255,255,255,.96); }
.lc-dark .lc-reference small { color: #5d6675; }
.lc-page-hero { padding-top: clamp(2rem, 4vw, 3rem); }
.lc-service-kicker { display: inline-flex; margin-bottom: 1rem; padding: .35rem .7rem; border-radius: 999px; background: #e7f0ff; color: var(--lc-blue); font-weight: 850; font-size: .88rem; }

.lc-media-text {
  align-items: center !important;
  gap: clamp(2rem, 5vw, 5rem) !important;
}
.lc-media-text .wp-block-image img,
.wp-block-media-text__media img {
  border-radius: var(--lc-radius-lg);
  box-shadow: var(--lc-shadow);
}
.wp-block-media-text__content { padding: 0 clamp(1rem, 3vw, 3rem) !important; }
.lc-list {
  margin: 1.2rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: .75rem;
}
.lc-list li {
  position: relative;
  padding-left: 2rem;
}
.lc-list li::before {
  content: "✓";
  position: absolute;
  left: 0; top: 0;
  width: 1.35rem; height: 1.35rem;
  display: grid; place-items: center;
  border-radius: 999px;
  background: #e7f0ff;
  color: var(--lc-blue);
  font-size: .85rem;
  font-weight: 900;
}

.lc-contact-grid {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 1.15rem;
  align-items: stretch;
}
.lc-contact-card h3 { margin-bottom: .4rem; }
.lc-contact-card a { font-weight: 900; }

/* Posts */
.post-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.2rem;
  padding: 3rem 0 5rem;
}
.post-card {
  padding: 1.25rem;
  border: 1px solid var(--lc-line);
  border-radius: var(--lc-radius);
  box-shadow: var(--lc-shadow-soft);
  background: #fff;
}
.post-card a { text-decoration: none; }
.post-meta { color: var(--lc-muted); font-size: .92rem; margin-bottom: .5rem; }
.single-post .entry-content { padding-bottom: 5rem; }

/* Footer */
.site-footer {
  background: var(--lc-black);
  color: #c9d8ed;
  padding: 4rem 0 1.5rem;
}
.site-footer__grid {
  display: grid;
  grid-template-columns: 1.2fr .8fr .8fr .8fr;
  gap: 2rem;
}
.site-footer h2,
.site-footer h3,
.site-footer strong { color: #fff; }
.site-footer a { color: #e9fbff; text-decoration: none; }
.site-footer a:hover { color: var(--lc-blue); }
.site-footer ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .55rem; }
.site-footer__bottom {
  border-top: 1px solid rgba(255,255,255,.12);
  margin-top: 3rem;
  padding-top: 1.2rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1rem;
  color: #90a4bf;
  font-size: .92rem;
}

/* Forms */
input[type="text"], input[type="email"], input[type="tel"], textarea, select {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--lc-line);
  border-radius: 12px;
  padding: .75rem .9rem;
  font: inherit;
}
textarea { min-height: 160px; }
button, input[type="submit"] {
  border: none;
  border-radius: 999px;
  background: var(--lc-blue);
  color: #fff;
  padding: .88rem 1.2rem;
  font-weight: 850;
  cursor: pointer;
}

/* Responsive */
@media (max-width: 1100px) {
  .header-cta { display: none; }
  .lc-card-grid, .lc-process { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lc-reference-grid, .lc-gallery-grid, .post-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .site-footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 860px) {
  .site-header__inner { min-height: 72px; }
  .nav-toggle { display: inline-flex; }
  .primary-nav {
    position: fixed;
    top: 72px;
    left: 20px;
    right: 20px;
    display: none;
    padding: .8rem;
    border: 1px solid var(--lc-line);
    border-radius: 22px;
    background: var(--lc-black);
    box-shadow: var(--lc-shadow);
  }
  body.nav-open .primary-nav { display: block; }
  .primary-menu { display: grid; gap: .2rem; align-items: stretch; }
  .primary-menu a { display: flex; border-radius: 12px; }
  .primary-menu .sub-menu {
    position: static;
    min-width: 0;
    margin: .2rem 0 .5rem 1rem;
    padding: .2rem;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: none;
    box-shadow: none;
    border: none;
    background: #10141c;
  }
  .lc-hero .wp-block-columns,
  .wp-block-columns { flex-wrap: wrap !important; }
  .wp-block-column { flex-basis: 100% !important; }
  .lc-hero-card, .lc-hero-card img, .lc-hero-card .wp-block-image img { min-height: 360px; }
  .lc-contact-grid, .lc-metric-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  :root { --lc-container: min(100vw - 28px, 1180px); }
  body { font-size: 16px; }
  .brand__claim { display: none; }
  .lc-card-grid, .lc-reference-grid, .lc-gallery-grid, .lc-process, .post-list, .site-footer__grid { grid-template-columns: 1fr; }
  .lc-reference { min-height: 86px; }
  .lc-content .wp-block-buttons { flex-direction: column; align-items: stretch; }
  .lc-content .wp-block-button, .lc-content .wp-block-button__link { width: 100%; }
}
@media (max-width: 860px) {
  .site-header .primary-menu .sub-menu a { color: rgba(255,255,255,.86); }
  .site-header .primary-menu .sub-menu a:hover { color: #fff; background: rgba(0,109,255,.20); }
}

/* Business-card refresh: logo top-left and blue from the card */
:root {
  --lc-sky: #45c4f3;
  --lc-sky-soft: #dff6ff;
  --lc-blue-rgb: 0, 140, 195;
}

.site-header {
  background: rgba(255,255,255,.94);
  border-bottom: 1px solid rgba(0,140,195,.18);
  box-shadow: 0 12px 32px rgba(0,61,90,.07);
}
.site-header__inner { min-height: 86px; }
.site-header .brand { color: var(--lc-ink); flex: 0 0 auto; }
.brand__logo {
  display: block;
  width: min(320px, 42vw);
  max-height: 58px;
  object-fit: contain;
  object-position: left center;
}
.site-header .primary-menu a {
  color: var(--lc-ink);
  background: transparent;
}
.site-header .primary-menu a:hover,
.site-header .primary-menu .current-menu-item > a,
.site-header .primary-menu .current-menu-ancestor > a {
  background: rgba(var(--lc-blue-rgb),.12);
  color: var(--lc-blue-2);
}
.site-header .primary-menu .sub-menu {
  background: var(--lc-white);
  border-color: rgba(var(--lc-blue-rgb),.18);
}
.site-header .primary-menu .sub-menu a { color: var(--lc-ink); }
.site-header .primary-menu .sub-menu a:hover { color: var(--lc-blue-2); background: var(--lc-sky-soft); }
.header-cta {
  background: linear-gradient(135deg, var(--lc-blue), var(--lc-sky));
  color: #fff;
  box-shadow: 0 16px 32px rgba(var(--lc-blue-rgb),.28);
}
.header-cta:hover { background: var(--lc-black); color: #fff; }
.nav-toggle { border-color: rgba(var(--lc-blue-rgb),.24); color: var(--lc-ink); }
.nav-toggle span:first-child,
.nav-toggle span:first-child::before,
.nav-toggle span:first-child::after {
  background: var(--lc-ink);
}

.lc-hero {
  position: relative;
  overflow: hidden;
  padding: clamp(4rem, 8vw, 8rem) 0 clamp(3rem, 6vw, 6rem);
  background:
    radial-gradient(circle at 12% 18%, rgba(69,196,243,.58), transparent 30%),
    linear-gradient(180deg, rgba(69,196,243,.86) 0%, #ffffff 42%, #f6fcff 100%);
}
.lc-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(115deg, rgba(255,255,255,.72) 0 34%, transparent 34% 100%),
    radial-gradient(circle at 90% 20%, rgba(0,140,195,.20), transparent 28%);
  pointer-events: none;
}
.lc-hero > * { position: relative; z-index: 1; }
.lc-hero h1 { color: var(--lc-black); max-width: 11ch; }
.lc-hero .lc-lead { color: #284151; }
.lc-eyebrow {
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(255,255,255,.76);
  color: var(--lc-blue-2);
  box-shadow: 0 10px 28px rgba(0,61,90,.08);
}
.lc-hero-card {
  min-height: 540px;
  background: #f7fbfd;
  border: 1px solid rgba(255,255,255,.78);
  box-shadow: 0 28px 80px rgba(0,61,90,.18);
}
.lc-hero-card img,
.lc-hero-card .wp-block-image img { min-height: 540px; }
.lc-hero-card::after { background: linear-gradient(180deg, transparent 35%, rgba(5,5,5,.70)); }
.lc-hero-badge { background: rgba(5,5,5,.78); }

.lc-home-intro {
  transform: translateY(-2.5rem);
  margin-bottom: -1rem;
}
.lc-home-intro__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}
.lc-home-proof {
  padding: 1.25rem;
  border-radius: var(--lc-radius);
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(var(--lc-blue-rgb),.16);
  box-shadow: var(--lc-shadow-soft);
}
.lc-home-proof strong { display: block; font-size: 1.25rem; margin-bottom: .25rem; }
.lc-home-proof span { color: var(--lc-muted); }

.lc-card { border-top-color: var(--lc-blue); }
.lc-card__icon,
.lc-list li::before,
.lc-service-kicker {
  background: var(--lc-sky-soft);
  color: var(--lc-blue-2);
}
.wp-block-button__link,
.lc-button,
button,
input[type="submit"] {
  background: linear-gradient(135deg, var(--lc-blue), var(--lc-sky));
  color: #fff;
  box-shadow: 0 14px 26px rgba(var(--lc-blue-rgb),.22);
}
.wp-block-button__link:hover,
.lc-button:hover,
button:hover,
input[type="submit"]:hover { background: var(--lc-black); color: #fff; }
.is-style-outline .wp-block-button__link {
  background: rgba(255,255,255,.74);
  border: 1px solid rgba(var(--lc-blue-rgb),.25);
  color: var(--lc-blue-2);
  box-shadow: none;
}
.is-style-outline .wp-block-button__link:hover { background: var(--lc-black); color: #fff; }

.lc-dark {
  background:
    radial-gradient(circle at 82% 0%, rgba(69,196,243,.34), transparent 34%),
    linear-gradient(135deg, #050505 0%, #07151f 100%);
}
.lc-reference::before { background: linear-gradient(180deg, var(--lc-sky), var(--lc-blue-2)); }
.site-footer {
  background: linear-gradient(135deg, #050505, #07151f);
}
.site-footer a:hover { color: var(--lc-sky); }

.lc-home-split {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 1.3rem;
  align-items: center;
}
.lc-home-split__text {
  padding: clamp(1.4rem, 3vw, 2.4rem);
  border-radius: var(--lc-radius-lg);
  background: var(--lc-white);
  border: 1px solid rgba(var(--lc-blue-rgb),.14);
  box-shadow: var(--lc-shadow-soft);
}
.lc-logo-panel {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin: 1.4rem 0 0;
}
.lc-logo-panel__mark {
  padding: .75rem 1rem;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(69,196,243,.38), rgba(255,255,255,.9));
  border: 1px solid rgba(var(--lc-blue-rgb),.18);
  font-weight: 900;
  color: var(--lc-blue-2);
}

@media (max-width: 1100px) {
  .brand__logo { width: min(260px, 48vw); }
  .lc-home-intro__grid { grid-template-columns: 1fr; }
  .lc-home-split { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .site-header__inner { min-height: 74px; }
  .brand__logo { width: min(230px, 66vw); max-height: 46px; }
  .primary-nav {
    top: 74px;
    background: var(--lc-white);
    border-color: rgba(var(--lc-blue-rgb),.22);
  }
  .primary-menu .sub-menu { background: var(--lc-sky-soft); }
  .site-header .primary-menu .sub-menu a { color: var(--lc-ink); }
  .site-header .primary-menu .sub-menu a:hover { color: var(--lc-blue-2); background: rgba(255,255,255,.72); }
  .lc-home-intro { transform: none; margin: 1rem 0 0; }
}
@media (max-width: 640px) {
  .brand__logo { width: min(210px, 68vw); }
  .lc-hero { padding-top: 3rem; }
  .lc-hero h1 { max-width: none; }
}


/* Version 2.3.0: Startseite, Footer-Blau, stabile Dropdowns, globale Kontaktdaten */
:root {
  --lc-blue: #008cc3;
  --lc-blue-2: #006f9f;
  --lc-sky: #45c4f3;
  --lc-sky-soft: #e4f8ff;
  --lc-blue-rgb: 0, 140, 195;
}

/* Dropdown-Fix: kein Abstand zwischen Menüpunkt und Untermenü */
.primary-menu > li { position: relative; }
.primary-menu .sub-menu {
  top: 100% !important;
  margin-top: 0 !important;
  z-index: 2000;
  transform: translateY(0) !important;
  transition: opacity 150ms ease, visibility 150ms ease !important;
}
.primary-menu .sub-menu::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -10px;
  height: 10px;
}
.primary-menu li:hover > .sub-menu,
.primary-menu li:focus-within > .sub-menu {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

/* Header Logo bleibt links klar sichtbar */
.brand__logo {
  width: min(300px, 40vw);
  max-height: 60px;
  object-fit: contain;
  object-position: left center;
}

/* Neue Startseite ohne Absatz-/Block-Probleme */
.lc-homepage {
  width: 100%;
  overflow: hidden;
  background: #fff;
  color: var(--lc-text);
}
.lc-homepage a { text-decoration: none; }
.lc-home-hero {
  position: relative;
  padding: clamp(4rem, 8vw, 8rem) 0 clamp(3rem, 6vw, 5.5rem);
  background:
    radial-gradient(circle at 8% 18%, rgba(69,196,243,.58), transparent 28%),
    linear-gradient(115deg, rgba(255,255,255,.96) 0%, rgba(255,255,255,.92) 48%, rgba(69,196,243,.34) 48%, rgba(0,140,195,.58) 100%),
    #e9f9ff;
}
.lc-home-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, rgba(255,255,255,.65) 0 30%, transparent 30% 100%);
  pointer-events: none;
}
.lc-home-hero__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(340px, .78fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.lc-home-hero__content h1 {
  max-width: 950px;
  margin-bottom: 1.25rem;
  color: #050505;
  font-size: clamp(2.6rem, 6.4vw, 5.8rem);
  line-height: .98;
  letter-spacing: -.065em;
  font-weight: 900;
}
.lc-kicker {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin: 0 0 1rem;
  padding: .48rem .78rem;
  border-radius: 999px;
  color: var(--lc-blue-2);
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(255,255,255,.82);
  font-size: .92rem;
  font-weight: 900;
  letter-spacing: .01em;
  box-shadow: 0 10px 28px rgba(0,61,90,.08);
}
.lc-kicker--dark {
  color: #042234;
  background: rgba(255,255,255,.82);
  border-color: rgba(255,255,255,.72);
}
.lc-home-lead {
  max-width: 760px;
  color: #284151;
  font-size: clamp(1.08rem, 1.8vw, 1.26rem);
  line-height: 1.75;
}
.lc-home-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  margin-top: 1.6rem;
}
.lc-button--light {
  background: rgba(255,255,255,.86) !important;
  color: var(--lc-blue-2) !important;
  border: 1px solid rgba(var(--lc-blue-rgb),.25);
  box-shadow: none !important;
}
.lc-button--light:hover { background: var(--lc-black) !important; color: #fff !important; }
.lc-home-visual {
  position: relative;
  min-height: 510px;
  border-radius: var(--lc-radius-lg);
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(255,255,255,.82);
  box-shadow: 0 28px 80px rgba(0,61,90,.18);
}
.lc-home-visual__img {
  width: 100%;
  height: 100%;
  min-height: 510px;
  object-fit: cover;
  display: block;
}
.lc-home-visual::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 48%;
  background: linear-gradient(180deg, transparent, rgba(5,5,5,.72));
}
.lc-home-visual__badge {
  position: absolute;
  z-index: 2;
  left: 22px;
  right: 22px;
  bottom: 22px;
  padding: 1rem 1.1rem;
  border-radius: 18px;
  color: #fff;
  background: rgba(5,5,5,.76);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(10px);
}
.lc-home-visual__badge strong,
.lc-home-visual__badge span { display: block; color: #fff; }
.lc-home-strip {
  position: relative;
  z-index: 2;
  margin-top: -2.2rem;
}
.lc-home-strip__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}
.lc-home-strip article,
.lc-home-card,
.lc-home-steps article,
.lc-home-partners article,
.lc-home-contact__card {
  padding: clamp(1.2rem, 2.1vw, 1.65rem);
  border-radius: var(--lc-radius);
  background: rgba(255,255,255,.95);
  border: 1px solid rgba(var(--lc-blue-rgb),.16);
  box-shadow: var(--lc-shadow-soft);
}
.lc-home-strip strong,
.lc-home-strip span,
.lc-home-partners strong,
.lc-home-partners span,
.lc-home-steps strong,
.lc-home-steps span { display: block; }
.lc-home-strip strong,
.lc-home-partners strong,
.lc-home-steps strong { color: #050505; font-size: 1.12rem; margin-bottom: .35rem; }
.lc-home-strip span,
.lc-home-partners span,
.lc-home-steps span { color: var(--lc-muted); line-height: 1.55; }
.lc-home-section,
.lc-page-section {
  padding: clamp(3.5rem, 7vw, 6.5rem) 0;
}
.lc-home-section--soft { background: #f4fbfe; }
.lc-home-section--blue {
  background:
    radial-gradient(circle at 84% 12%, rgba(255,255,255,.38), transparent 32%),
    linear-gradient(135deg, var(--lc-sky), var(--lc-blue));
  color: #042234;
}
.lc-home-section--blue h2,
.lc-home-section--blue h3,
.lc-home-section--blue strong { color: #042234; }
.lc-home-section--blue p { color: rgba(4,34,52,.84); }
.lc-section-head--left { text-align: left; margin-inline: 0; }
.lc-home-services {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.15rem;
}
.lc-home-card { border-top: 4px solid var(--lc-blue); }
.lc-home-card span:first-child {
  display: inline-grid;
  place-items: center;
  width: 56px;
  height: 56px;
  margin-bottom: 1rem;
  border-radius: 18px;
  background: var(--lc-sky-soft);
  color: var(--lc-blue-2);
  font-size: .9rem;
  font-weight: 900;
}
.lc-home-card h3 { margin-bottom: .6rem; }
.lc-home-card p { color: var(--lc-muted); }
.lc-home-card a { font-weight: 900; }
.lc-home-split-new,
.lc-home-image-text,
.lc-home-contact {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
}
.lc-home-steps {
  display: grid;
  gap: .9rem;
}
.lc-home-section--blue .lc-home-steps article,
.lc-home-section--blue .lc-home-contact__card {
  background: rgba(255,255,255,.88);
  border-color: rgba(255,255,255,.62);
}
.lc-home-image-text > div:last-child {
  padding: clamp(1.4rem, 3vw, 2.4rem);
  border-radius: var(--lc-radius-lg);
  background: #fff;
  border: 1px solid rgba(var(--lc-blue-rgb),.14);
  box-shadow: var(--lc-shadow-soft);
}
.lc-home-partners {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}
.lc-home-partners article { text-align: center; }
.lc-home-partners strong { font-size: 1.25rem; }
.lc-reference-grid--home { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.lc-home-contact__card a:not(.lc-button) { font-weight: 900; color: var(--lc-blue-2); }
.lc-home-final { padding-bottom: clamp(3rem, 6vw, 5.5rem); }

/* Footer unten komplett im Visitenkarten-Blau */
.site-footer {
  background:
    radial-gradient(circle at 16% 10%, rgba(255,255,255,.34), transparent 28%),
    linear-gradient(135deg, var(--lc-blue-2) 0%, var(--lc-blue) 46%, var(--lc-sky) 100%) !important;
  color: #f4fcff !important;
  padding: 4rem 0 1.5rem;
}
.site-footer__grid {
  align-items: start;
}
.site-footer__brand {
  display: inline-flex;
  align-items: center;
  padding: .72rem .86rem;
  margin-bottom: 1.1rem;
  border-radius: 18px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 14px 34px rgba(0,61,90,.16);
}
.site-footer__logo {
  display: block;
  width: min(265px, 72vw);
  max-height: 58px;
  object-fit: contain;
  object-position: left center;
}
.site-footer h2,
.site-footer h3,
.site-footer strong { color: #fff !important; }
.site-footer p,
.site-footer li,
.site-footer__bottom { color: rgba(255,255,255,.88) !important; }
.site-footer a { color: #fff !important; text-decoration: none; font-weight: 800; }
.site-footer a:hover { color: #042234 !important; }
.site-footer__bottom {
  border-top: 1px solid rgba(255,255,255,.28);
}

@media (max-width: 1100px) {
  .lc-home-hero__grid,
  .lc-home-split-new,
  .lc-home-image-text,
  .lc-home-contact { grid-template-columns: 1fr; }
  .lc-home-visual,
  .lc-home-visual__img { min-height: 420px; }
  .lc-home-strip__grid,
  .lc-home-partners,
  .lc-reference-grid--home { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 860px) {
  .primary-menu .sub-menu::before { display: none; }
  .primary-menu .sub-menu { top: auto !important; }
}
@media (max-width: 640px) {
  .brand__logo { width: min(210px, 68vw); }
  .lc-home-actions { flex-direction: column; align-items: stretch; }
  .lc-home-actions .lc-button { width: 100%; }
  .lc-home-strip__grid,
  .lc-home-services,
  .lc-home-partners,
  .lc-reference-grid--home { grid-template-columns: 1fr; }
  .lc-home-hero__content h1 { font-size: clamp(2.3rem, 12vw, 3.7rem); }
  .lc-home-visual,
  .lc-home-visual__img { min-height: 330px; }
  .site-footer__logo { width: min(235px, 76vw); }
}


/* Version 2.4.0: echte Full-Width-Startseite und stabileres Leistungen-Dropdown */
.lc-front-main {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden;
  background: #fff;
}
.lc-front-main > * {
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
.lc-front-main .lc-homepage {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
}
body.home .lc-content,
body.front-page .lc-content,
body.home .entry-content,
body.front-page .entry-content {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
body.home .lc-content > *:not(.alignfull),
body.front-page .lc-content > *:not(.alignfull),
body.home .entry-content > *:not(.alignfull),
body.front-page .entry-content > *:not(.alignfull) {
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* Header darf breit laufen, Inhalt bleibt sauber gepolstert */
.site-header__inner {
  width: min(1440px, calc(100vw - 48px));
  max-width: min(1440px, calc(100vw - 48px));
}

/* Dropdown: keine Hover-Lücke, genug Fläche, zuverlässig über dem Hero */
.primary-menu .menu-item-has-children > a {
  position: relative;
}
.primary-menu .menu-item-has-children > a::after {
  content: "";
  width: .42em;
  height: .42em;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
  margin-left: .2rem;
  opacity: .68;
}
.primary-menu .sub-menu {
  top: calc(100% - 1px) !important;
  margin-top: 0 !important;
  padding-top: .82rem !important;
  z-index: 5000 !important;
}
.primary-menu .sub-menu::before {
  top: -14px !important;
  height: 18px !important;
}
.primary-menu li:hover > .sub-menu,
.primary-menu li:focus-within > .sub-menu,
.primary-menu li.focus > .sub-menu {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

@media (max-width: 860px) {
  .site-header__inner {
    width: min(100vw - 28px, 1440px);
    max-width: min(100vw - 28px, 1440px);
  }
  .primary-menu .menu-item-has-children > a::after { display: none; }
}

/* Version 2.5.0: transparentes Footer-Logo sauber zentriert */
.site-footer__brandcol {
  min-width: 0;
}
.site-footer__brand {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: min(295px, 100%) !important;
  min-height: 86px;
  padding: 0 !important;
  margin: 0 0 1.15rem 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
.site-footer__logo {
  display: block !important;
  width: min(285px, 100%) !important;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  object-position: center center !important;
}
@media (max-width: 640px) {
  .site-footer__brand {
    width: min(270px, 100%) !important;
  }
  .site-footer__logo {
    width: min(260px, 100%) !important;
  }
}

/* Version 2.6.0: Unterseiten im Startseiten-Layout, neue Leistungsseiten, Partnerlogos */
.lc-content > .lcpro-designed-page,
.lcpro-designed-page,
.lcpro-designed-content,
.lcpro-designed-content > .lc-homepage {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
.lcpro-designed-page .entry-content,
.lcpro-designed-content > * {
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
.lc-subpage .lc-sub-hero {
  padding-top: clamp(3.6rem, 7vw, 7rem);
  padding-bottom: clamp(3rem, 6vw, 5.2rem);
}
.lc-subpage .lc-home-hero__content h1 {
  max-width: 980px;
}
.lc-home-services--six {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.lc-home-card span:first-child {
  overflow: hidden;
  white-space: nowrap;
}
.lc-home-partners--logos {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  align-items: stretch;
}
.lc-partner-logo-card {
  min-height: 182px;
  padding: 1.35rem !important;
  border-radius: var(--lc-radius);
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(var(--lc-blue-rgb),.16);
  box-shadow: var(--lc-shadow-soft);
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .9rem;
  text-align: center;
}
.lc-partner-logo {
  display: block;
  width: 100%;
  max-width: 240px;
  height: 86px;
  object-fit: contain;
  object-position: center;
}
.lc-partner-logo-card span {
  display: block;
  color: var(--lc-ink);
  font-size: .95rem;
  font-weight: 850;
  line-height: 1.35;
}
.lc-subpage--provider .lc-home-hero,
.lc-subpage--alarmierung .lc-home-hero {
  background:
    radial-gradient(circle at 8% 18%, rgba(69,196,243,.58), transparent 28%),
    linear-gradient(115deg, rgba(255,255,255,.97) 0%, rgba(255,255,255,.93) 48%, rgba(69,196,243,.30) 48%, rgba(0,140,195,.56) 100%),
    #e9f9ff;
}
.lc-home-card a,
.lc-reference a {
  overflow-wrap: anywhere;
}
@media (max-width: 1100px) {
  .lc-home-services--six,
  .lc-home-partners--logos {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 640px) {
  .lc-home-services--six,
  .lc-home-partners--logos {
    grid-template-columns: 1fr;
  }
  .lc-partner-logo-card {
    min-height: 160px;
  }
  .lc-partner-logo {
    height: 76px;
    max-width: 220px;
  }
}


/* Version 2.6.1: Footer unten ausgewogener, besser lesbar, schwarze Schrift */
.site-footer__inner {
  width: min(1320px, calc(100vw - 48px));
  max-width: min(1320px, calc(100vw - 48px));
}
.site-footer__grid {
  grid-template-columns: minmax(280px, 1.25fr) repeat(3, minmax(170px, .82fr)) !important;
  gap: clamp(1.5rem, 3vw, 3rem) !important;
  align-items: start;
}
.site-footer__brandcol {
  max-width: 360px;
}
.site-footer__brand {
  width: min(230px, 100%) !important;
  min-height: auto !important;
  margin-bottom: 1rem !important;
}
.site-footer__logo {
  width: min(210px, 100%) !important;
}
.site-footer h2 {
  margin: 0 0 1rem;
  font-size: clamp(2.2rem, 3.5vw, 3rem);
  line-height: 1.03;
  letter-spacing: -0.04em;
}
.site-footer h3 {
  margin: .2rem 0 1rem;
  font-size: 1.05rem;
}
.site-footer h2,
.site-footer h3,
.site-footer strong,
.site-footer p,
.site-footer li,
.site-footer a,
.site-footer__bottom,
.site-footer__bottom span {
  color: #09131d !important;
}
.site-footer a:hover {
  color: rgba(9, 19, 29, .74) !important;
}
.site-footer__bottom {
  border-top: 1px solid rgba(9, 19, 29, .18) !important;
}
@media (max-width: 1180px) {
  .site-footer__grid {
    grid-template-columns: minmax(260px, 1.2fr) repeat(3, minmax(150px, 1fr)) !important;
  }
}
@media (max-width: 980px) {
  .site-footer__grid {
    grid-template-columns: 1fr 1fr !important;
  }
  .site-footer__brandcol {
    max-width: none;
  }
}
@media (max-width: 640px) {
  .site-footer__inner {
    width: min(100vw - 28px, 1320px);
    max-width: min(100vw - 28px, 1320px);
  }
  .site-footer__grid {
    grid-template-columns: 1fr !important;
  }
  .site-footer__brand,
  .site-footer__logo {
    width: min(210px, 100%) !important;
  }
}


/* Version 2.6.2: Footer-Logo größer und Schrift weicher */
.site-footer__brand {
  width: min(320px, 100%) !important;
  margin-bottom: 1.15rem !important;
}
.site-footer__logo {
  width: min(300px, 100%) !important;
}
.site-footer h2 {
  max-width: 320px;
  font-size: clamp(2rem, 3.2vw, 2.7rem);
  line-height: 1.02;
}
.site-footer h2,
.site-footer h3,
.site-footer strong,
.site-footer p,
.site-footer li,
.site-footer a,
.site-footer__bottom,
.site-footer__bottom span {
  color: #14384d !important;
}
.site-footer a:hover {
  color: #0d2b3d !important;
}
.site-footer__bottom {
  border-top: 1px solid rgba(20, 56, 77, .18) !important;
}
@media (max-width: 640px) {
  .site-footer__brand {
    width: min(280px, 100%) !important;
  }
  .site-footer__logo {
    width: min(270px, 100%) !important;
  }
  .site-footer h2 {
    max-width: 280px;
  }
}


/* Version 2.6.3: transparentes Header-Logo und überarbeitete News-/Archivseite */
.brand__logo {
  width: min(300px, 32vw) !important;
  max-height: 62px !important;
  object-fit: contain !important;
  object-position: left center !important;
}
.entry-header--news {
  padding: clamp(3rem, 7vw, 5.5rem) 0 1.5rem;
}
.entry-header--news .entry-title {
  max-width: 780px;
}
.entry-intro {
  max-width: 780px;
  color: #496171;
  font-size: 1.08rem;
}
.post-list {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 1.5rem !important;
  padding: 2.25rem 0 4.75rem !important;
}
.post-card {
  display: flex;
  flex-direction: column;
  padding: 1.45rem !important;
  min-height: 100%;
}
.post-card h2 {
  margin: 0 0 .8rem;
  font-size: clamp(1.55rem, 2.2vw, 2.2rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
}
.post-card h2 a {
  color: var(--lc-blue) !important;
}
.post-card h2 a:hover {
  color: var(--lc-blue-2) !important;
}
.post-meta {
  color: #6a7a88;
  font-size: .88rem;
  font-weight: 700;
  letter-spacing: .01em;
  margin-bottom: .75rem;
}
.post-excerpt {
  color: #334754;
  font-size: .98rem;
  line-height: 1.75;
  margin-bottom: 1.15rem;
}
.post-excerpt p:last-child {
  margin-bottom: 0;
}
.post-link {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-weight: 800;
  color: var(--lc-blue-2) !important;
  text-decoration: none;
}
.post-link:hover {
  color: var(--lc-navy) !important;
}
.nav-links {
  width: var(--lc-container);
  max-width: var(--lc-container);
  margin: -1.5rem auto 4.5rem;
  display: flex;
  justify-content: center;
  gap: .65rem;
  flex-wrap: wrap;
}
.nav-links .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 46px;
  min-height: 46px;
  padding: .65rem .95rem;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--lc-line);
  color: var(--lc-ink);
  text-decoration: none;
  font-weight: 800;
}
.nav-links .page-numbers.current,
.nav-links .page-numbers:hover {
  background: rgba(0,140,195,.12);
  border-color: rgba(0,140,195,.24);
  color: var(--lc-blue-2);
}
@media (max-width: 980px) {
  .post-list {
    grid-template-columns: 1fr !important;
  }
  .brand__logo {
    width: min(270px, 44vw) !important;
  }
}
@media (max-width: 640px) {
  .brand__logo {
    width: min(220px, 62vw) !important;
    max-height: 48px !important;
  }
  .entry-intro {
    font-size: 1rem;
  }
}


/* Version 2.6.4: Header-Logo kommt direkt aus dem Theme, Seiten werden beim Setup nicht überschrieben */


/* Version 2.6.5: Adresse und Geschäftszeiten im Footer ergänzt */
.site-footer__contact {
  display: grid;
  gap: .55rem;
  margin-top: 1rem;
}
.site-footer__contact p {
  margin: 0 !important;
  line-height: 1.55;
}
.site-footer__contact strong {
  display: inline-block;
  margin-bottom: .05rem;
}
@media (max-width: 980px) {
  .site-footer__contact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .8rem 1.2rem;
  }
}
@media (max-width: 640px) {
  .site-footer__contact {
    grid-template-columns: 1fr;
  }
}
