@import url("/static/nikari-brand-font.css");


:root {
  color-scheme: light;
  --color-bg: #f8f3ed;
  --color-surface: #ffffff;
  --color-text: #151515;
  --color-muted: #444844;
  --color-border: rgba(23, 22, 18, 0.13);
  --color-border-strong: rgba(23, 22, 18, 0.24);
  --color-accent-red: #b92b24;
  --color-brand-blue: #263344;
  --color-gold: #dac9a6;
  --color-brand-blue-soft: rgba(38, 51, 68, 0.08);
  --color-brand-blue-line: rgba(38, 51, 68, 0.18);
  --color-status-online: #218553;
  --color-status-offline: #b92b24;
  --shadow-soft: 0 18px 54px rgba(22, 22, 18, 0.09);
  --shadow-card: 0 12px 34px rgba(22, 22, 18, 0.07);
  --max: 1160px;
  --radius: 8px;
  --font: var(--nikari-font, "Nikari Lato", Lato, "Helvetica Neue", Arial, sans-serif);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background:
    radial-gradient(circle at 16% 14%, rgba(218, 201, 166, .18), transparent 30%),
    linear-gradient(145deg, #f8f3ed 0%, #fffdf9 52%, #f8f3ed 100%);
  color: var(--color-text);
  font-family: var(--font);
  font-size: 16px;
  font-weight: 300;
  line-height: 1.58;
  letter-spacing: 0;
  transition: background-color .24s ease, color .24s ease;
}
body.nav-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
p { margin: 0; color: var(--color-muted); font-weight: 300; }
img { max-width: 100%; height: auto; }
button, input, select, textarea { font: inherit; }
.skip-link {
  position: fixed;
  left: 16px;
  top: 12px;
  z-index: 100;
  transform: translateY(-160%);
  background: var(--color-text);
  color: #fff;
  padding: 10px 14px;
  border-radius: var(--radius);
}
.skip-link:focus { transform: translateY(0); }
:focus-visible { outline: 3px solid rgba(38, 51, 68, 0.34); outline-offset: 3px; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid rgba(23, 22, 18, 0.08);
  background: rgba(248, 243, 237, 0.90);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  transition: background-color .24s ease, box-shadow .22s ease, border-color .22s ease;
}
.site-header.is-scrolled { box-shadow: 0 14px 34px rgba(22,22,18,.06); border-color: rgba(23,22,18,.13); }
.nav {
  position: relative;
  width: min(var(--max), calc(100% - 32px));
  min-height: 72px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 24px;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 156px;
  font-weight: 800;
  letter-spacing: .18em;
}
.brand img { width: 34px; height: 34px; object-fit: contain; }
.brand span { color: var(--color-brand-blue); }
.origin-badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 36px;
  margin-left: clamp(20px, 4vw, 78px);
  margin-right: auto;
  padding: 0 13px 0 11px;
  border: 1px solid rgba(38,51,68,.14);
  border-radius: 999px;
  background: rgba(255,255,255,.48);
  color: var(--color-brand-blue);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  box-shadow: 0 8px 22px rgba(22,22,18,.04);
}
.origin-cross {
  position: relative;
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  border-radius: 4px;
  background: var(--color-accent-red);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18);
}
.origin-cross::before,
.origin-cross::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  border-radius: 1px;
  background: #fff;
  transform: translate(-50%, -50%);
}
.origin-cross::before { width: 10px; height: 3px; }
.origin-cross::after { width: 3px; height: 10px; }
.nav-links {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-left: 0;
  color: rgba(21,21,21,.68);
  font-size: 14px;
  white-space: nowrap;
}
.nav-links a { min-height: 44px; display: inline-flex; align-items: center; }
.nav-links a:hover, .nav-links a[aria-current="page"] { color: var(--color-brand-blue); }
.nav-cta, .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border: 1px solid var(--color-border-strong);
  border-radius: 999px;
  background: rgba(255,255,255,.58);
  color: var(--color-text);
  font-weight: 800;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.nav-cta:hover, .button:hover { transform: translateY(-1px); border-color: rgba(23,22,18,.34); box-shadow: 0 10px 22px rgba(22,22,18,.08); }
.button.primary { background: var(--color-brand-blue); color: #fff; border-color: var(--color-brand-blue); box-shadow: 0 14px 34px rgba(38,51,68,.18); }
.button.primary:hover { background: #1f2b39; border-color: #1f2b39; }
.button.secondary { background: rgba(255,255,255,.74); border-color: rgba(38,51,68,.22); color: var(--color-brand-blue); }
.nav-toggle {
  display: none;
  width: 46px;
  height: 46px;
  margin-left: auto;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: rgba(255,255,255,.66);
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
}
.nav-toggle span { width: 18px; height: 2px; background: var(--color-text); transition: transform .2s ease; }
.nav-toggle[aria-expanded="true"] span:first-child { transform: translateY(3.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:last-child { transform: translateY(-3.5px) rotate(-45deg); }
main { overflow: hidden; }
.section {
  width: min(var(--max), calc(100% - 32px));
  margin: 0 auto;
  padding: 82px 0;
}
.home-hero {
  position: relative;
  isolation: isolate;
  min-height: calc(100svh - 72px);
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .78fr);
  align-items: center;
  gap: 58px;
  padding-top: 62px;
  padding-bottom: 74px;
}
.home-hero::before {
  content: "";
  position: absolute;
  z-index: -1;
  left: max(-32px, calc((100vw - var(--max)) / -2));
  top: 118px;
  width: 10px;
  height: 54%;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--color-brand-blue), var(--color-gold));
  opacity: .95;
}
.home-hero::after {
  content: "";
  position: absolute;
  z-index: -1;
  inset: 118px auto auto 34%;
  width: 420px;
  height: 1px;
  background: var(--color-brand-blue-line);
}
.page-hero { padding-top: 96px; padding-bottom: 50px; }
.hero-copy { max-width: 760px; }
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  color: rgba(21,21,21,.62);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .13em;
}
.eyebrow::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--color-accent-red);
  box-shadow: 0 0 0 6px rgba(185,43,36,.10);
}
.status-line::before { display: none; }
.system-status-badge { display: inline-flex; align-items: center; gap: 10px; min-height: 24px; white-space: nowrap; }
.status-dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--color-status-offline);
  box-shadow: 0 0 0 6px rgba(185,43,36,.10);
}
.system-status-badge.is-online .status-dot { background: var(--color-status-online); box-shadow: 0 0 0 6px rgba(33,133,83,.11); }
.system-status-badge.is-offline .status-dot { background: var(--color-status-offline); }
h1 {
  max-width: 820px;
  margin: 0;
  font-size: clamp(42px, 6.6vw, 84px);
  line-height: .95;
  letter-spacing: 0;
}
.page-hero h1 { font-size: clamp(40px, 5.4vw, 72px); }
.lead {
  max-width: 720px;
  margin-top: 24px;
  font-size: clamp(18px, 1.9vw, 22px);
  color: rgba(21,21,21,.82);
}
.plain-explainer {
  max-width: 690px;
  display: grid;
  grid-template-columns: 122px minmax(0,1fr);
  gap: 14px;
  align-items: start;
  margin-top: 24px;
  padding: 16px 18px;
  border: 1px solid var(--color-brand-blue-line);
  border-left: 4px solid var(--color-brand-blue);
  border-radius: var(--radius);
  background: rgba(255,255,255,.72);
  box-shadow: 0 12px 36px rgba(38,51,68,.06);
}
.plain-explainer strong { color: var(--color-brand-blue); }
.plain-explainer span { color: rgba(21,21,21,.82); }
.plain-explainer [data-simple-rotator] {
  display: block;
  min-height: 3.2em;
}
.actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 30px; }
.trust-row { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 28px; }
.trust-row span, .prompt-row span {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 8px 12px;
  background: rgba(255,255,255,.70);
  color: var(--color-brand-blue);
  font-size: 14px;
}
.hero-visual {
  position: relative;
  min-height: 510px;
  border: 1px solid rgba(38,51,68,.18);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: 0 28px 82px rgba(38,51,68,.15);
  overflow: hidden;
  animation: visualFloat 7s ease-in-out infinite;
}
.hero-visual::before, .hero-visual::after {
  content: "";
  position: absolute;
  border: 1px solid rgba(21,21,21,.12);
  border-radius: 50%;
}
.hero-visual::before { inset: 36px; border-color: rgba(38,51,68,.15); }
.hero-visual::after { inset: 96px; border-color: rgba(185,43,36,.20); }
.visual-core {
  position: absolute;
  inset: 50%;
  width: 166px;
  height: 166px;
  transform: translate(-50%, -50%);
  border-radius: var(--radius);
  background: var(--color-brand-blue);
  display: grid;
  place-items: center;
  box-shadow: 0 18px 46px rgba(22,22,18,.18);
}
.visual-core img { width: 108px; height: 108px; object-fit: contain; }
.visual-card {
  position: absolute;
  width: 174px;
  min-height: 96px;
  padding: 15px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: rgba(255,255,255,.82);
  box-shadow: var(--shadow-card);
  animation: cardDrift 8s ease-in-out infinite;
}
.visual-card strong { display: block; margin-bottom: 5px; color: var(--color-brand-blue); }
.visual-card span { color: var(--color-muted); font-size: 13px; line-height: 1.38; }
.visual-status {
  position: absolute;
  z-index: 3;
  top: 18px;
  right: 18px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid rgba(38,51,68,.14);
  border-radius: 999px;
  background: rgba(255,255,255,.82);
  color: var(--color-brand-blue);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
}
.visual-status span {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-status-online);
  box-shadow: 0 0 0 5px rgba(33,133,83,.10);
}
.card-docs { top: 42px; left: 38px; }
.card-rooms { top: 74px; right: 34px; animation-delay: -.7s; }
.card-answer { bottom: 56px; left: 56px; animation-delay: -1.4s; }
.card-audit { bottom: 42px; right: 48px; animation-delay: -2.1s; }
.band { border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); background: rgba(255,255,255,.34); }
.split-section { display: grid; grid-template-columns: minmax(0,.86fr) minmax(0,1fr); gap: 52px; align-items: start; }
.section-heading { max-width: 760px; margin-bottom: 28px; }
h2, h3 { margin: 0 0 12px; line-height: 1.16; letter-spacing: 0; }
h2[id], h3[id] { scroll-margin-top: 96px; }
h2 { font-size: clamp(30px, 4vw, 48px); }
h3 { font-size: 22px; }
.kicker { color: var(--color-accent-red); font-weight: 800; font-size: 13px; text-transform: uppercase; letter-spacing: .12em; margin-bottom: 10px; }
.text-block { display: grid; gap: 22px; font-size: 18px; }
.grid-3, .grid-2 { display: grid; gap: 18px; }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.card {
  min-height: 188px;
  padding: 24px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: rgba(255,255,255,.68);
  box-shadow: 0 1px 0 rgba(255,255,255,.82) inset;
}
.card.lift { transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.card.lift:hover { transform: translateY(-3px); box-shadow: 0 18px 46px rgba(38,51,68,.11); border-color: rgba(38,51,68,.24); }
.card a:not(.button) { display: inline-flex; margin-top: 18px; color: var(--color-text); font-weight: 800; border-bottom: 1px solid var(--color-border-strong); }
.feature-card { display: flex; flex-direction: column; align-items: flex-start; gap: 12px; }
.feature-card .button { margin-top: auto; }
.process { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 12px; }
.process-step {
  position: relative;
  min-height: 176px;
  padding: 20px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: rgba(255,255,255,.68);
  transition: transform .22s ease, border-color .22s ease, background .22s ease;
}
.process-step span, .timeline-item span {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 1px solid var(--color-border-strong);
  display: grid;
  place-items: center;
  color: var(--color-accent-red);
  font-weight: 800;
  margin-bottom: 18px;
}
.process-step.is-active { transform: translateY(-3px); border-color: rgba(38,51,68,.30); background: rgba(255,255,255,.90); box-shadow: 0 14px 34px rgba(38,51,68,.08); }
.audience-list { display: grid; gap: 18px; }
.audience-card { min-height: auto; }
.prompt-row { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 20px; }
.timeline { display: grid; gap: 16px; }
.timeline-item {
  display: grid;
  grid-template-columns: 52px minmax(0,1fr);
  gap: 18px;
  padding: 22px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: rgba(255,255,255,.68);
}
.timeline-item span { margin: 0; }
.faq-list { display: grid; gap: 12px; }
.faq-item { padding: 24px; border: 1px solid var(--color-border); border-radius: var(--radius); background: rgba(255,255,255,.7); }
.faq-item h2 { font-size: 24px; }
.cta-section { text-align: center; max-width: 820px; }
.cta-section .actions { justify-content: center; }
.contact-lines { display: grid; gap: 8px; margin-top: 14px; font-weight: 800; }
.contact-form { display: grid; gap: 14px; }
.contact-form label { display: grid; gap: 6px; color: rgba(21,21,21,.74); font-weight: 800; }
.contact-form input, .contact-form select, .contact-form textarea {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius);
  background: #fff;
  padding: 10px 12px;
  color: var(--color-text);
}
.contact-form textarea { resize: vertical; min-height: 128px; }
.placeholder {
  margin-top: 18px;
  padding: 14px;
  border: 1px dashed rgba(185,43,36,.35);
  border-radius: var(--radius);
  background: rgba(185,43,36,.05);
  color: rgba(21,21,21,.82);
}
.site-footer {
  border-top: 1px solid var(--color-border);
  padding: 44px 0 30px;
  color: var(--color-muted);
}
.footer-inner {
  width: min(var(--max), calc(100% - 32px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(220px, .9fr) minmax(360px, 1.15fr) minmax(240px, .72fr);
  gap: clamp(28px, 4vw, 64px);
  align-items: start;
}
.footer-brand { display: grid; gap: 7px; max-width: 340px; }
.footer-brand strong { color: var(--color-text); letter-spacing: .16em; font-size: 15px; line-height: 1; }
.footer-brand span { max-width: 310px; line-height: 1.35; }
.footer-links {
  display: grid;
  grid-template-columns: repeat(2, minmax(145px, 1fr));
  gap: 9px 24px;
  align-content: start;
  justify-self: center;
  max-width: 470px;
  line-height: 1.25;
}
.footer-links a {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
}
.footer-links a:hover, .footer-contact a:hover { color: var(--color-text); }
.footer-contact {
  display: grid;
  gap: 8px;
  justify-items: end;
  text-align: right;
  line-height: 1.3;
}
.footer-contact a { color: var(--color-text); font-weight: 700; }
.footer-contact span { max-width: 280px; }
.reveal { opacity: 1; transform: none; }
.js .reveal { opacity: 0; transform: translateY(14px); transition: opacity .95s ease, transform .95s ease; }
.js .reveal.is-visible { opacity: 1; transform: translateY(0); }
@keyframes titleWordReveal {
  0% { opacity: 0; transform: translateY(.42em); filter: blur(6px); }
  58% { opacity: .86; filter: blur(1px); }
  100% { opacity: 1; transform: translateY(0); filter: blur(0); }
}
.js .is-animated-title .title-word {
  display: inline-block;
  opacity: 0;
  transform: translateY(.42em);
  animation: titleWordReveal 1.45s cubic-bezier(.18,.72,.18,1) forwards;
  animation-delay: calc(var(--i) * 155ms);
  will-change: opacity, transform, filter;
}
@keyframes visualFloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
@keyframes cardDrift { 0%,100% { transform: translateY(0); } 50% { transform: translateY(5px); } }
@keyframes statusPulse { 0%,100% { box-shadow: 0 0 0 5px rgba(33,133,83,.10); } 50% { box-shadow: 0 0 0 9px rgba(33,133,83,.04); } }
.system-status-badge.is-online .status-dot { animation: statusPulse 3.2s ease-in-out infinite; }
/* Zielbild navigation: more public sections without adding new app routes. */
.nav {
  width: min(1460px, calc(100% - 32px));
  gap: 16px;
}
.nav-links {
  gap: 11px;
  font-size: 12.5px;
}
@media (max-width: 1180px) {
  .origin-badge {
    min-width: 38px;
    width: 38px;
    padding: 0;
    justify-content: center;
    margin-left: auto;
    margin-right: 12px;
  }
  .origin-badge span:last-child {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
  }
}
@media (max-width: 1320px) {
  .origin-badge {
    min-width: 38px;
    width: 38px;
    padding: 0;
    justify-content: center;
    margin-left: auto;
    margin-right: 8px;
  }
  .origin-badge span:last-child {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
  }
}
@media (max-width: 1080px) {
  .nav { min-height: 64px; }
  .nav-toggle { margin-left: 0; display: inline-flex; }
  .nav-links {
    position: fixed;
    left: 12px;
    right: 12px;
    top: 74px;
    display: grid;
    gap: 4px;
    padding: 14px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: rgba(255,255,255,.96);
    box-shadow: var(--shadow-soft);
    white-space: normal;
    transform: translateY(-10px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .18s ease, transform .18s ease;
  }
  .nav-links.is-open { opacity: 1; transform: translateY(0); pointer-events: auto; }
  .nav-links a { min-height: 46px; padding: 0 10px; border-radius: var(--radius); }
  .nav-links a:hover { background: rgba(23,22,18,.04); }
  .nav-cta { justify-self: start; padding: 0 16px !important; }
}
@media (max-width: 1024px) {
  .home-hero { grid-template-columns: 1fr; min-height: auto; gap: 36px; padding-top: 54px; }
  .hero-visual { min-height: 440px; max-width: 620px; width: 100%; margin: 0 auto; }
  .grid-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .process { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .footer-inner { grid-template-columns: 1fr; gap: 22px; }
  .footer-links { justify-self: stretch; max-width: none; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .footer-contact { justify-items: start; text-align: left; }
}
@media (max-width: 820px) {
  .nav { min-height: 64px; }
  .nav-toggle { margin-left: 0; }
  .nav-toggle { display: inline-flex; }
  .nav-links {
    position: fixed;
    left: 12px;
    right: 12px;
    top: 74px;
    display: grid;
    gap: 4px;
    padding: 14px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: rgba(255,255,255,.96);
    box-shadow: var(--shadow-soft);
    white-space: normal;
    transform: translateY(-10px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .18s ease, transform .18s ease;
  }
  .nav-links.is-open { opacity: 1; transform: translateY(0); pointer-events: auto; }
  .nav-links a { min-height: 46px; padding: 0 10px; border-radius: var(--radius); }
  .nav-links a:hover { background: rgba(23,22,18,.04); }
  .nav-cta { justify-self: start; padding: 0 16px !important; }
  .split-section, .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .section { padding: 64px 0; }
  .page-hero { padding-top: 72px; padding-bottom: 34px; }
}
@media (max-width: 560px) {
  .site-footer { padding: 34px 0 26px; }
  .section, .nav, .footer-inner { width: min(100% - 24px, var(--max)); }
  .footer-links { grid-template-columns: 1fr; gap: 8px; }
  .brand { min-width: 0; }
  .brand span { display: none; }
  h1 { font-size: clamp(38px, 12vw, 50px); }
  .lead { font-size: 17px; }
  .button { width: 100%; min-height: 48px; }
  .plain-explainer { grid-template-columns: 1fr; gap: 4px; }
  .plain-explainer [data-simple-rotator] { min-height: 5.4em; }
  .trust-row span, .prompt-row span { width: 100%; border-radius: var(--radius); }
  .region-label { display: none; }
  .home-hero::before, .home-hero::after { display: none; }
  .hero-visual { min-height: 390px; }
  .visual-core { width: 122px; height: 122px; }
  .visual-core img { width: 82px; height: 82px; }
  .visual-card { width: 138px; min-height: 82px; padding: 11px; }
  .visual-card span { font-size: 12px; }
  .card-docs { top: 24px; left: 18px; }
  .card-rooms { top: 42px; right: 16px; }
  .card-answer { bottom: 40px; left: 18px; }
  .card-audit { bottom: 24px; right: 16px; }
  .process { grid-template-columns: 1fr; }
  .process-step { min-height: auto; }
  .timeline-item { grid-template-columns: 1fr; }
}
@media (max-width: 360px) {
  .visual-card { width: 128px; }
  .visual-card strong { font-size: 14px; }
  .eyebrow { font-size: 12px; letter-spacing: .08em; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
  }
  .js .reveal, .reveal { opacity: 1; transform: none; }
  .js .is-animated-title .title-word { opacity: 1; transform: none; filter: none; animation: none; }
}

.typewriter-cursor::after { content: none; display: none; }
.hero-signal {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}
.hero-signal span {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 12px;
  border: 1px solid rgba(38,51,68,.16);
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  color: var(--color-brand-blue);
  font-size: 13px;
  font-weight: 800;
}
.hero-signal span::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-gold);
}
.ai-demo-section { padding-top: 74px; }
.ai-demo {
  display: grid;
  grid-template-columns: minmax(220px, .42fr) minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
}
.demo-prompts {
  display: grid;
  gap: 10px;
}
.demo-prompt {
  min-height: 58px;
  border: 1px solid rgba(38,51,68,.18);
  border-radius: var(--radius);
  background: rgba(255,255,255,.70);
  color: rgba(21,21,21,.74);
  padding: 14px 16px;
  text-align: left;
  cursor: pointer;
  font-weight: 800;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.demo-prompt:hover,
.demo-prompt.is-active {
  transform: translateY(-2px);
  border-color: rgba(38,51,68,.32);
  background: #fff;
  color: var(--color-brand-blue);
  box-shadow: 0 14px 34px rgba(38,51,68,.08);
}
.demo-answer {
  min-height: 278px;
  padding: 24px;
  border: 1px solid rgba(38,51,68,.18);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(255,255,255,.94), rgba(255,255,255,.72)),
    radial-gradient(circle at top right, rgba(218,201,166,.28), transparent 34%);
  box-shadow: var(--shadow-card);
}
.demo-answer-top {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 22px;
  color: var(--color-brand-blue);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .09em;
}
.demo-answer-top strong {
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(38,51,68,.16);
  background: rgba(248,243,237,.78);
  color: rgba(21,21,21,.70);
  text-transform: none;
  letter-spacing: 0;
}
.demo-question {
  margin-bottom: 14px;
  color: var(--color-text);
  font-size: clamp(20px, 2vw, 28px);
  font-weight: 800;
  line-height: 1.2;
}
.demo-typing {
  min-height: 92px;
  color: rgba(21,21,21,.82);
  font-size: 18px;
}
.source-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}
.source-pills span {
  border: 1px solid rgba(38,51,68,.16);
  border-radius: 999px;
  padding: 7px 10px;
  background: rgba(248,243,237,.82);
  color: var(--color-brand-blue);
  font-size: 13px;
  font-weight: 800;
}
.accordion {
  display: grid;
  gap: 10px;
}
.accordion details {
  border: 1px solid rgba(38,51,68,.16);
  border-radius: var(--radius);
  background: rgba(255,255,255,.70);
  box-shadow: 0 1px 0 rgba(255,255,255,.82) inset;
}
.accordion summary {
  min-height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 16px 18px;
  color: var(--color-brand-blue);
  cursor: pointer;
  font-weight: 700;
  list-style: none;
}
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary::after {
  content: "+";
  width: 28px;
  height: 28px;
  flex: 0 0 28px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(38,51,68,.18);
  border-radius: 50%;
  background: rgba(248,243,237,.78);
  color: var(--color-brand-blue);
}
.accordion details[open] summary::after { content: "−"; }
.accordion details p {
  padding: 0 18px 18px;
  max-width: 820px;
}
@keyframes cursorBlink { 50% { opacity: .15; } }
@media (max-width: 820px) {
  .ai-demo { grid-template-columns: 1fr; }
  .demo-prompts { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .hero-signal span { width: calc(50% - 4px); border-radius: var(--radius); }
  .demo-answer { padding: 18px; }
  .demo-answer-top { align-items: flex-start; flex-direction: column; }
  .demo-typing { min-height: 140px; font-size: 16px; }
  .demo-prompt { min-height: 54px; }
}
@media (prefers-reduced-motion: reduce) {
  .typewriter-cursor::after { display: none; }
}


/* NIKARI editorial image hero */
h1, h2, h3,
.brand,
.button,
.nav-cta,
.kicker,
.demo-prompt,
.nav-links,
.footer-brand strong,
strong {
  font-weight: 700;
}
.home-page .site-header {
  background: rgba(248,243,237,.92);
}
.home-page .home-hero {
  width: 100%;
  max-width: none;
  min-height: min(640px, calc(78svh - 72px));
  margin: 0;
  padding: clamp(58px, 7vh, 86px) max(20px, calc((100vw - var(--max)) / 2)) 54px;
  grid-template-columns: minmax(0, 810px);
  align-content: center;
  gap: 0;
  color: #fff;
  background:
    linear-gradient(90deg, rgba(38,51,68,.64) 0%, rgba(38,51,68,.50) 48%, rgba(38,51,68,.30) 100%),
    url("/site/images/nikari-hero-lobby.jpg") center 47% / cover no-repeat;
}
.home-page .home-hero::before {
  left: max(16px, calc((100vw - var(--max)) / 2 - 24px));
  top: clamp(144px, 18vh, 202px);
  width: 5px;
  height: min(48%, 420px);
  background: linear-gradient(180deg, var(--color-gold), rgba(218,201,166,.28));
  opacity: .95;
}
.home-page .home-hero::after { display: none; }
.home-page .hero-copy { max-width: 810px; }
.home-page .hero-visual { display: none; }
.home-page .home-hero h1 {
  max-width: 840px;
  color: #fff;
  font-size: clamp(34px, 4.1vw, 56px);
  font-weight: 300;
  line-height: 1.06;
  text-shadow: 0 18px 48px rgba(0,0,0,.34);
}
.home-page .home-hero .lead {
  max-width: 760px;
  color: rgba(255,255,255,.86);
  font-weight: 300;
  font-size: clamp(17px, 1.45vw, 20px);
  line-height: 1.52;
  text-shadow: 0 10px 30px rgba(0,0,0,.28);
}
.home-page .home-hero .eyebrow,
.home-page .home-hero .region-label {
  color: rgba(255,255,255,.78);
}
.home-page .home-hero .plain-explainer {
  max-width: 690px;
  border-color: rgba(218,201,166,.34);
  border-left-color: var(--color-gold);
  background: rgba(248,243,237,.13);
  box-shadow: 0 22px 58px rgba(0,0,0,.20);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.home-page .home-hero .plain-explainer strong {
  color: #fff;
}
.home-page .home-hero .plain-explainer span {
  color: rgba(255,255,255,.82);
}
.home-page .home-hero .hero-signal span,
.home-page .home-hero .trust-row span {
  border-color: rgba(218,201,166,.28);
  background: rgba(248,243,237,.12);
  color: rgba(255,255,255,.86);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.home-page .home-hero .button.primary {
  background: #fff;
  color: var(--color-brand-blue);
  border-color: #fff;
  box-shadow: 0 16px 46px rgba(0,0,0,.24);
}
.home-page .home-hero .button.secondary {
  background: rgba(255,255,255,.12);
  color: #fff;
  border-color: rgba(255,255,255,.42);
}
.home-page .home-hero .status-dot {
  box-shadow: 0 0 0 6px rgba(255,255,255,.14);
}
.media-card {
  overflow: hidden;
  padding: 0;
}
.card-image {
  display: block;
  width: 100%;
  height: 168px;
  object-fit: cover;
}
.media-card .card-body {
  padding: 24px;
}
.audience-list .media-card {
  display: grid;
  grid-template-columns: minmax(220px, .36fr) minmax(0, 1fr);
  align-items: stretch;
}
.audience-list .media-card .card-image {
  height: 100%;
  min-height: 260px;
}
.audience-list .media-card .card-body {
  padding: 28px;
}
@media (max-width: 820px) {
  .home-page .home-hero {
    min-height: calc(84svh - 64px);
    padding-top: 68px;
    padding-bottom: 54px;
    background:
      linear-gradient(180deg, rgba(38,51,68,.58), rgba(38,51,68,.42)),
      url("/site/images/nikari-hero-lobby.jpg") center / cover no-repeat;
  }
  .audience-list .media-card { grid-template-columns: 1fr; }
  .audience-list .media-card .card-image { height: 210px; min-height: 0; }
}
@media (max-width: 560px) {
  .home-page .home-hero {
    padding-left: 20px;
    padding-right: 20px;
    background-position: center;
  }
  .home-page .home-hero h1 {
    font-size: clamp(32px, 9vw, 42px);
    font-weight: 300;
    line-height: 1.05;
  }
  .home-page .home-hero .lead {
    font-size: 16px;
    line-height: 1.5;
  }
  .home-page .home-hero .hero-signal,
  .home-page .home-hero .trust-row {
    display: none;
  }
  .card-image { height: 150px; }
}


/* NIKARI final content system */
.process.process-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.compact-grid { align-items: start; }
.check-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 18px;
  color: var(--color-muted);
}
.check-list li { padding-left: 3px; }
.note-box,
.legal-note {
  border: 1px solid rgba(38,51,68,.18);
  border-left: 4px solid var(--color-gold);
  border-radius: var(--radius);
  background: rgba(255,255,255,.72);
  padding: 22px;
  box-shadow: var(--shadow-card);
}
.note-box strong { display: block; margin-bottom: 8px; color: var(--color-brand-blue); }
.price-grid,
.price-teaser {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.price-card h3 {
  color: var(--color-brand-blue);
  font-size: clamp(24px, 2.7vw, 34px);
}
.price-for,
.fineprint {
  color: rgba(21,21,21,.82);
}
.price-teaser article {
  min-height: 112px;
  padding: 18px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: rgba(255,255,255,.72);
}
.price-teaser strong,
.price-teaser span {
  display: block;
}
.price-teaser span {
  margin-top: 8px;
  color: var(--color-brand-blue);
  font-weight: 700;
}
.compare-table {
  display: grid;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  background: rgba(255,255,255,.72);
}
.compare-table [role="row"] {
  display: grid;
  grid-template-columns: .68fr 1fr 1fr;
  border-top: 1px solid var(--color-border);
}
.compare-table [role="row"]:first-child { border-top: 0; }
.compare-table [role="row"] > div {
  padding: 16px;
  border-left: 1px solid var(--color-border);
}
.compare-table [role="row"] > div:first-child {
  border-left: 0;
  font-weight: 700;
  color: var(--color-brand-blue);
}
.compare-head {
  background: rgba(38,51,68,.06);
  font-weight: 700;
}
.mailto-box .check-list { margin-top: 8px; }
.home-page .status-line { gap: 12px; }
.home-page .region-label { display: none; }
@media (max-width: 1180px) {
  .origin-badge {
    min-width: 38px;
    width: 38px;
    padding: 0;
    justify-content: center;
    margin-left: auto;
    margin-right: 12px;
  }
  .origin-badge span:last-child {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
  }
}
@media (max-width: 1024px) {
  .process.process-6 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .price-grid,
  .price-teaser { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 820px) {
  .compare-table,
  .compare-table [role="row"] {
    display: grid;
  }
  .compare-table [role="row"] {
    grid-template-columns: 1fr;
  }
  .compare-table [role="row"] > div {
    border-left: 0;
    border-top: 1px solid var(--color-border);
  }
  .compare-table [role="row"] > div:first-child {
    border-top: 0;
    background: rgba(38,51,68,.05);
  }
  .compare-head { display: none !important; }
}
@media (max-width: 560px) {
  .home-page .region-label { display: none; }
  .process.process-6,
  .price-grid,
  .price-teaser { grid-template-columns: 1fr; }
}


/* NIKARI v18 dynamic visual system */
.js .home-page .home-hero .eyebrow,
.js .home-page .home-hero .lead,
.js .home-page .home-hero .plain-explainer,
.js .home-page .home-hero .actions,
.js .home-page .home-hero .trust-row,
.js .home-page .hero-system {
  opacity: 0;
  transform: translateY(16px);
  animation: heroLayerIn 1.45s cubic-bezier(.18,.72,.18,1) forwards;
}
.js .home-page .home-hero .eyebrow { animation-delay: .08s; }
.js .home-page .home-hero .lead { animation-delay: .42s; }
.js .home-page .home-hero .plain-explainer { animation-delay: .58s; }
.js .home-page .home-hero .actions { animation-delay: .72s; }
.js .home-page .home-hero .trust-row { animation-delay: .86s; }
.js .home-page .hero-system { animation-delay: .62s; }
@keyframes heroLayerIn {
  to { opacity: 1; transform: translateY(0); }
}
.hero-system {
  position: absolute;
  right: max(28px, calc((100vw - var(--max)) / 2));
  top: 56%;
  width: min(28vw, 360px);
  min-width: 320px;
  aspect-ratio: 1 / .86;
  translate: 0 -50%;
  border: 1px solid rgba(218,201,166,.22);
  border-radius: 14px;
  background: linear-gradient(145deg, rgba(248,243,237,.12), rgba(38,51,68,.12));
  box-shadow: 0 28px 80px rgba(0,0,0,.28);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  pointer-events: none;
  overflow: hidden;
}
.hero-system::before,
.hero-system::after {
  content: "";
  position: absolute;
  border: 1px solid rgba(218,201,166,.18);
  border-radius: 50%;
  inset: 34px;
}
.hero-system::after {
  inset: 92px;
  border-color: rgba(185,43,36,.20);
}
.hero-system-orbit {
  position: absolute;
  inset: 58px;
  border-radius: 50%;
  background: conic-gradient(from 40deg, rgba(218,201,166,.0), rgba(218,201,166,.42), rgba(218,201,166,.0), rgba(185,43,36,.26), rgba(218,201,166,.0));
  opacity: .46;
  animation: orbitBreathe 7.5s ease-in-out infinite;
}
.hero-system-core {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 112px;
  height: 112px;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  gap: 4px;
  border-radius: 16px;
  background: rgba(10,12,14,.76);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 22px 58px rgba(0,0,0,.32);
  color: #fff;
  letter-spacing: .18em;
  font-size: 11px;
}
.hero-system-core img { width: 48px; height: 48px; object-fit: contain; }
.hero-system-card {
  position: absolute;
  width: 126px;
  min-height: 68px;
  padding: 12px;
  border: 1px solid rgba(218,201,166,.26);
  border-radius: 10px;
  background: rgba(248,243,237,.15);
  color: rgba(255,255,255,.84);
  box-shadow: 0 14px 36px rgba(0,0,0,.16);
  animation: subtleFloat 7s ease-in-out infinite;
}
.hero-system-card strong { display: block; color: #fff; font-size: 14px; margin-bottom: 3px; }
.hero-system-card span { font-size: 12px; color: rgba(255,255,255,.70); }
.hero-system-docs { left: 24px; top: 28px; }
.hero-system-rooms { right: 20px; top: 62px; animation-delay: -1.4s; }
.hero-system-sources { left: 34px; bottom: 34px; animation-delay: -2.6s; }
.hero-system-boundary { right: 30px; bottom: 24px; animation-delay: -3.8s; }
@keyframes subtleFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-7px); }
}
@keyframes orbitBreathe {
  0%, 100% { opacity: .34; transform: scale(.98); }
  50% { opacity: .56; transform: scale(1.02); }
}
.flow-process {
  position: relative;
}
.flow-process::before {
  content: "";
  position: absolute;
  left: 3%;
  right: 3%;
  top: 36px;
  height: 1px;
  background: linear-gradient(90deg, rgba(38,51,68,.10), rgba(218,201,166,.82), rgba(38,51,68,.10));
}
.flow-process .process-step {
  overflow: hidden;
  isolation: isolate;
}
.flow-process .process-step::after {
  content: "";
  position: absolute;
  inset: auto 18px 14px 18px;
  height: 2px;
  background: linear-gradient(90deg, rgba(185,43,36,.12), rgba(218,201,166,.85));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .65s ease;
}
.flow-process .process-step.is-active::after {
  transform: scaleX(1);
}
.data-room-map {
  position: relative;
  min-height: 430px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  padding: clamp(18px, 3vw, 34px);
  border: 1px solid rgba(38,51,68,.14);
  border-radius: 14px;
  background:
    radial-gradient(circle at 50% 50%, rgba(218,201,166,.24), transparent 34%),
    rgba(255,255,255,.50);
  box-shadow: var(--shadow-card);
}
.data-room-core {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 176px;
  min-height: 112px;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  text-align: center;
  padding: 18px;
  border: 1px solid rgba(38,51,68,.18);
  border-radius: 14px;
  background: var(--color-brand-blue);
  color: #fff;
  box-shadow: 0 24px 58px rgba(38,51,68,.20);
}
.data-room-core span { font-weight: 700; letter-spacing: .18em; }
.data-room-core small { color: rgba(255,255,255,.68); line-height: 1.35; }
.data-room {
  min-height: 170px;
  padding: 22px;
  border: 1px solid rgba(38,51,68,.14);
  border-radius: 12px;
  background: rgba(255,255,255,.78);
  box-shadow: 0 1px 0 rgba(255,255,255,.9) inset;
}
.data-room span,
.pilot-node span,
.price-path-step span {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(218,201,166,.24);
  color: var(--color-brand-blue);
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 12px;
}
.data-room strong,
.pilot-node strong,
.price-path-step strong {
  display: block;
  color: var(--color-text);
  font-size: 20px;
  margin-bottom: 7px;
}
.pilot-map,
.price-path {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.pilot-map { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.pilot-node,
.price-path-step,
.price-factor {
  position: relative;
  min-height: 170px;
  padding: 22px;
  border: 1px solid rgba(38,51,68,.14);
  border-radius: 12px;
  background: rgba(255,255,255,.72);
  box-shadow: 0 1px 0 rgba(255,255,255,.9) inset;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.pilot-node:hover,
.price-path-step:hover,
.price-factor:hover {
  transform: translateY(-3px);
  border-color: rgba(38,51,68,.26);
  box-shadow: 0 18px 42px rgba(38,51,68,.09);
}
.price-path {
  margin-bottom: 18px;
}
.compact-path {
  margin-bottom: 24px;
}
.price-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 100%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.62)),
    radial-gradient(circle at top right, rgba(218,201,166,.20), transparent 38%);
}
.price-card h3 {
  margin: 0;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(38,51,68,.12);
}
.price-for {
  min-height: 52px;
  color: rgba(21,21,21,.76);
}
.price-factor-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.price-factor {
  min-height: 150px;
}
.price-factor strong {
  display: block;
  color: var(--color-brand-blue);
  font-size: 18px;
  margin-bottom: 8px;
}
.js .motion-item,
.js .price-card,
.js .timeline-item,
.js .pilot-node,
.js .data-room,
.js .price-factor {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .82s ease, transform .82s ease, box-shadow .22s ease, border-color .22s ease;
}
.js .motion-item.is-visible,
.js .price-card.is-visible,
.js .timeline-item.is-visible,
.js .pilot-node.is-visible,
.js .data-room.is-visible,
.js .price-factor.is-visible {
  opacity: 1;
  transform: translateY(0);
}
@media (max-width: 1180px) {
  .hero-system { display: none; }
}
@media (max-width: 1024px) {
  .pilot-map { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .price-factor-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .data-room-map { grid-template-columns: 1fr; }
  .data-room-core {
    position: relative;
    left: auto;
    top: auto;
    transform: none;
    width: 100%;
    order: -1;
  }
}
@media (max-width: 700px) {
  .pilot-map,
  .price-path,
  .price-factor-grid { grid-template-columns: 1fr; }
  .flow-process::before { display: none; }
  .price-for { min-height: auto; }
}
@media (prefers-reduced-motion: reduce) {
  .hero-system-orbit,
  .hero-system-card {
    animation: none !important;
  }
  .js .home-page .home-hero .eyebrow,
  .js .home-page .home-hero .lead,
  .js .home-page .home-hero .plain-explainer,
  .js .home-page .home-hero .actions,
  .js .home-page .home-hero .trust-row,
  .js .home-page .hero-system,
  .js .motion-item,
  .js .price-card,
  .js .timeline-item,
  .js .pilot-node,
  .js .data-room,
  .js .price-factor {
    opacity: 1;
    transform: none;
    animation: none;
  }
}


/* NIKARI v18 sharing, footer and chat polish */
.footer-bottom {
  width: min(var(--max), calc(100% - 32px));
  margin: 24px auto 0;
  display: none;
  justify-content: center;
  padding-top: 20px;
  border-top: 1px solid rgba(38,51,68,.08);
}
.footer-ss-icon {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(38,51,68,.12);
  border-radius: 50%;
  background: rgba(255,255,255,.54);
  box-shadow: 0 12px 30px rgba(38,51,68,.08);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.footer-ss-icon:hover,
.footer-ss-icon:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(38,51,68,.28);
  box-shadow: 0 18px 40px rgba(38,51,68,.12);
}
.footer-ss-icon img { width: 22px; height: 22px; object-fit: contain; }
.hero-system-core {
  width: 128px;
  height: 128px;
  border-radius: 18px;
}
.hero-system-core img {
  width: 84px;
  height: auto;
  max-height: 94px;
}
.hero-system-card span { line-height: 1.3; }
@media (max-width: 820px) {
  .footer-bottom { justify-content: flex-start; }
}
@media (prefers-reduced-motion: reduce) {
  .footer-ss-icon { transition: none; }
  .footer-ss-icon:hover,
  .footer-ss-icon:focus-visible { transform: none; }
}


/* NIKARI v21 dashboard and slider */
:root {
  --nikari-dark-bg: #111923;
  --nikari-dark-bg-soft: #1b2633;
  --nikari-dark-text: #fffaf2;
  --nikari-dark-muted: rgba(255,250,242,.74);
  --nikari-dark-blue: #263344;
  --nikari-light-bg: #f8f3ed;
  --nikari-light-surface: #fffdf9;
  --nikari-light-beige: #dac9a6;
  --nikari-light-text: #151515;
  --nikari-light-muted: #4f514d;
  --nikari-border: rgba(38,51,68,.16);
  --nikari-red: #b92b24;
  --nikari-green: #218553;
  --nikari-shadow-soft: 0 24px 70px rgba(17,25,35,.16);
  --nikari-radius-card: 10px;
  --nikari-transition-theme: 520ms cubic-bezier(.2,.72,.18,1);
}
.theme-dark, [data-theme="dark"] {
  --theme-bg: var(--nikari-dark-bg);
  --theme-text: var(--nikari-dark-text);
  --theme-muted: var(--nikari-dark-muted);
  --theme-surface: rgba(255,255,255,.08);
  --theme-border: rgba(255,255,255,.15);
}
.theme-light, [data-theme="light"] {
  --theme-bg: var(--nikari-light-bg);
  --theme-text: var(--nikari-light-text);
  --theme-muted: var(--nikari-light-muted);
  --theme-surface: rgba(255,255,255,.76);
  --theme-border: rgba(38,51,68,.16);
}
.hero-slider {
  width: 100%;
  max-width: none;
  min-height: calc(100svh - 72px);
  padding: clamp(56px, 7vw, 86px) max(20px, calc((100vw - var(--max)) / 2)) clamp(58px, 7vw, 86px);
  color: var(--theme-text);
  background: var(--theme-bg);
  overflow: hidden;
  transition: background-color var(--nikari-transition-theme), color var(--nikari-transition-theme);
}
.hero-slider::before { display: none; }
.hero-slider::after { display: none; }
.hero-slider-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(5,10,16,.90) 0%, rgba(9,15,22,.72) 46%, rgba(9,15,22,.38) 100%),
    url("/site/images/nikari-hero-lobby.jpg") center/cover no-repeat;
  opacity: 1;
  transition: opacity var(--nikari-transition-theme), filter var(--nikari-transition-theme);
}
.hero-slider[data-theme="light"] .hero-slider-bg {
  background:
    radial-gradient(circle at 80% 20%, rgba(218,201,166,.34), transparent 34%),
    linear-gradient(120deg, rgba(248,243,237,.98), rgba(255,253,249,.88));
  filter: none;
}
.hero-slider .hero-copy {
  position: relative;
  z-index: 2;
  max-width: min(780px, 100%);
}
.hero-slide-eyebrow {
  display: inline-flex;
  margin-top: 2px;
  color: var(--theme-muted);
}
.hero-slide-eyebrow::before { background: var(--color-gold); box-shadow: 0 0 0 6px rgba(218,201,166,.12); }
.hero-slider .system-status-badge {
  color: var(--theme-text);
  letter-spacing: .13em;
}
.hero-slider[data-theme="light"] .system-status-badge { color: var(--nikari-light-text); }
.hero-slider h1 {
  min-height: clamp(160px, 22vw, 252px);
  max-width: 860px;
  font-size: clamp(3rem, 7vw, 7.35rem);
  line-height: .95;
  color: var(--theme-text);
  text-wrap: balance;
  transition: opacity .38s ease, transform .38s ease, color var(--nikari-transition-theme);
}
.hero-slider[data-theme="light"] h1 { color: var(--nikari-light-text); }
.hero-slider .lead {
  max-width: 810px;
  min-height: 78px;
  color: var(--theme-muted);
  transition: color var(--nikari-transition-theme), opacity .38s ease, transform .38s ease;
}
.hero-slider .plain-explainer {
  background: color-mix(in srgb, var(--theme-surface) 88%, transparent);
  border-color: var(--theme-border);
  border-left-color: var(--color-gold);
  color: var(--theme-text);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.hero-slider .plain-explainer strong,
.hero-slider .plain-explainer span { color: var(--theme-text); }
.hero-slider .trust-row span {
  background: color-mix(in srgb, var(--theme-surface) 82%, transparent);
  border-color: var(--theme-border);
  color: var(--theme-text);
}
.hero-slider[data-theme="light"] .plain-explainer,
.hero-slider[data-theme="light"] .trust-row span {
  color: var(--nikari-light-text);
  background: rgba(255,255,255,.72);
}
.hero-slider.is-changing h1,
.hero-slider.is-changing .lead,
.hero-slider.is-changing .plain-explainer { opacity: .45; transform: translateY(4px); }
.hero-slider .hero-system {
  z-index: 2;
  transition: opacity var(--nikari-transition-theme), transform var(--nikari-transition-theme);
}
.hero-slider[data-theme="light"] .hero-system {
  filter: invert(1) hue-rotate(180deg) saturate(.5);
  opacity: .72;
}
.hero-slider-controls {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 22px;
}
.hero-slider-controls > button,
.hero-dots button {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border: 1px solid var(--theme-border);
  border-radius: 999px;
  background: color-mix(in srgb, var(--theme-surface) 82%, transparent);
  color: var(--theme-text);
  cursor: pointer;
}
.hero-dots { display: inline-flex; align-items: center; gap: 8px; }
.hero-dots button {
  width: 12px;
  height: 12px;
  padding: 0;
  border-radius: 999px;
  opacity: .58;
}
.hero-dots button.is-active {
  width: 28px;
  opacity: 1;
  background: var(--color-gold);
  border-color: var(--color-gold);
}
.band.theme-dark,
.dark-band {
  width: 100%;
  max-width: none;
  background: linear-gradient(135deg, #111923, #1c2734);
  color: var(--nikari-dark-text);
  border-color: rgba(255,255,255,.1);
}
.dark-band h2, .dark-band h3, .dark-band strong { color: var(--nikari-dark-text); }
.dark-band p, .dark-band li { color: var(--nikari-dark-muted); }
.price-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}
.price-tabs a,
.price-badge {
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(38,51,68,.16);
  border-radius: 999px;
  background: rgba(255,255,255,.68);
  padding: 0 12px;
  color: var(--color-brand-blue);
  font-size: 13px;
  font-weight: 800;
}
.price-grid-modern { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.price-card h3 { margin-bottom: 8px; }
.price-value {
  margin: 8px 0 10px;
  color: var(--color-brand-blue);
  font-size: clamp(24px, 3vw, 34px);
  font-weight: 800;
  line-height: 1.05;
}
.price-card .check-list { margin-top: 18px; }
.price-card .price-badge { width: fit-content; margin-bottom: 16px; background: rgba(218,201,166,.18); }
.decision-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; }
.decision-card {
  min-height: 138px;
  padding: 20px;
  border: 1px solid rgba(38,51,68,.15);
  border-radius: var(--nikari-radius-card);
  background: rgba(255,255,255,.68);
  box-shadow: 0 12px 34px rgba(38,51,68,.06);
}
.decision-card strong { display: block; color: var(--color-brand-blue); margin-bottom: 8px; }
.price-panel { scroll-margin-top: 96px; }
.price-principle { max-width: 830px; }
@media (max-width: 1024px) {
  .hero-slider { grid-template-columns: 1fr; }
  .hero-slider h1 { min-height: auto; font-size: clamp(3.2rem, 9vw, 5.6rem); }
  .hero-slider .lead { min-height: auto; }
  .price-grid-modern, .decision-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 560px) {
  .hero-slider {
    min-height: calc(100svh - 64px);
    padding: 54px 20px 58px;
    align-content: start;
  }
  .hero-slider h1 {
    font-size: clamp(2.45rem, 11.6vw, 4rem);
    line-height: 1.02;
    min-height: auto;
  }
  .hero-slide-eyebrow { font-size: 11px; letter-spacing: .08em; }
  .hero-slider .lead { font-size: 16.5px; }
  .hero-slider .hero-system { display: none; }
  .hero-slider-controls { width: 100%; justify-content: center; }
  .price-grid-modern, .decision-grid { grid-template-columns: 1fr; }
  .price-tabs { display: grid; grid-template-columns: 1fr 1fr; }
  .price-tabs a { justify-content: center; }
}
@media (prefers-reduced-motion: reduce) {
  .hero-slider.is-changing h1,
  .hero-slider.is-changing .lead,
  .hero-slider.is-changing .plain-explainer { opacity: 1; transform: none; }
}


/* NIKARI v22 final rhythm */
.dark-band .process-step,
.dark-band .card,
.dark-band .price-path-step {
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.14);
  box-shadow: none;
}
.dark-band .process-step p,
.dark-band .process-step h3,
.dark-band .process-step span { color: var(--nikari-dark-text); }
.dark-cta {
  width: 100%;
  max-width: none;
  padding-left: max(20px, calc((100vw - var(--max)) / 2));
  padding-right: max(20px, calc((100vw - var(--max)) / 2));
  background: linear-gradient(135deg, #111923, #263344);
  border-top: 1px solid rgba(255,255,255,.10);
  border-bottom: 1px solid rgba(255,255,255,.10);
  color: var(--nikari-dark-text);
}
.dark-cta h2 { color: var(--nikari-dark-text); }
.dark-cta p:not(.kicker) { color: var(--nikari-dark-muted); }
.dark-cta .button.secondary {
  color: var(--nikari-dark-text);
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.18);
}


/* NIKARI v26 single hero correction */
.hero-single {
  grid-template-columns: minmax(0, 880px) !important;
  align-items: center !important;
}
.hero-single .hero-copy { max-width: 880px !important; }
.hero-single .hero-slider-controls,
.hero-single .hero-slide-eyebrow,
.hero-single .hero-system { display: none !important; }
.hero-single h1 {
  min-height: auto !important;
  max-width: 860px !important;
  font-weight: 800 !important;
}
.hero-single .lead,
.hero-single .plain-explainer { max-width: 760px !important; min-height: auto !important; }
.hero-single .status-line { margin-bottom: 28px !important; }
@media (min-width: 1025px) {
  .hero-single { min-height: calc(100svh - 72px) !important; }
}
@media (max-width: 720px) {
  .hero-single { padding-top: 72px !important; padding-bottom: 52px !important; }
  .hero-single h1 { font-size: clamp(38px, 11vw, 58px) !important; line-height: 1.02 !important; }
  .hero-single .status-line { margin-bottom: 22px !important; }
}

/* NIKARI browser theme mode v52 */
@media (prefers-color-scheme: dark) {
  :root {
    color-scheme: dark;
    --color-bg: #263344;
    --color-surface: #2f3d50;
    --color-text: #fffaf2;
    --color-muted: rgba(255, 250, 242, .76);
    --color-border: rgba(255, 250, 242, .14);
    --color-border-strong: rgba(255, 250, 242, .24);
    --color-brand-blue: #f8f3ed;
    --color-brand-blue-soft: rgba(248, 243, 237, .08);
    --color-brand-blue-line: rgba(248, 243, 237, .18);
    --shadow-soft: 0 18px 54px rgba(0, 0, 0, .24);
    --shadow-card: 0 14px 36px rgba(0, 0, 0, .22);
    --nikari-dark-bg: #263344;
    --nikari-dark-bg-soft: #2f3d50;
    --nikari-light-bg: #263344;
    --nikari-light-surface: #2f3d50;
    --nikari-light-text: #fffaf2;
    --nikari-light-muted: rgba(255, 250, 242, .76);
    --nikari-border: rgba(255, 250, 242, .16);
  }

  body {
    background:
      radial-gradient(circle at 14% 18%, rgba(38, 51, 68, .54), transparent 34%),
      radial-gradient(circle at 82% 12%, rgba(47, 61, 80, .24), transparent 30%),
      radial-gradient(circle at 86% 92%, rgba(38, 51, 68, .18), transparent 34%),
      linear-gradient(145deg, #0c0d0f 0%, #111417 40%, #18212c 70%, #0f1113 100%);
    color: var(--color-text);
  }

  .site-header {
    border-bottom-color: rgba(255, 250, 242, .12);
    background: rgba(12, 13, 15, .90);
    box-shadow: none;
  }

  .site-header.is-scrolled {
    border-color: rgba(255, 250, 242, .18);
    box-shadow: 0 14px 34px rgba(0, 0, 0, .18);
  }

  .brand img {
    filter: brightness(0) invert(1);
  }

  .brand span,
  .nav-links a:hover,
  .nav-links a[aria-current="page"],
  .footer-brand strong,
  .footer-links a:hover,
  .footer-contact a:hover {
    color: #fffaf2;
  }

  .nav-links {
    color: rgba(255, 250, 242, .72);
  }

  .origin-badge,
  .nav-cta,
  .button.secondary,
  .nav-toggle,
  .plain-explainer,
  .visual-card,
  .card,
  .faq-item,
  .contact-box,
  .note-box,
  .price-teaser article,
  .process-step,
  .source-pills span,
  .trust-row span,
  .prompt-row span {
    border-color: rgba(255, 250, 242, .15);
    background: rgba(255, 255, 255, .07);
    color: #fffaf2;
    box-shadow: 0 14px 36px rgba(0, 0, 0, .18);
  }

  .nav-cta:hover,
  .button.secondary:hover,
  .card:hover,
  .faq-item:hover {
    border-color: rgba(218, 201, 166, .38);
    background: rgba(255, 255, 255, .105);
  }

  .button.primary {
    background: #f8f3ed;
    border-color: #f8f3ed;
    color: #263344;
    box-shadow: 0 14px 34px rgba(0, 0, 0, .22);
  }

  .button.primary:hover {
    background: #fffaf2;
    border-color: #fffaf2;
  }

  .button.secondary {
    color: #fffaf2;
  }

  .band {
    border-color: rgba(255, 250, 242, .12);
    background: rgba(255, 255, 255, .045);
  }

  .dark-band,
  .theme-dark,
  [data-theme="dark"],
  .theme-light,
  [data-theme="light"] {
    --theme-bg: #263344;
    --theme-text: #fffaf2;
    --theme-muted: rgba(255, 250, 242, .76);
    --theme-surface: rgba(255, 255, 255, .08);
    --theme-border: rgba(255, 255, 255, .15);
  }

  .hero-slider-bg,
  .hero-slider[data-theme="light"] .hero-slider-bg {
    background:
      linear-gradient(90deg, rgba(38, 51, 68, .96) 0%, rgba(38, 51, 68, .82) 48%, rgba(38, 51, 68, .62) 100%),
      url("/site/images/nikari-hero-lobby.jpg") center/cover no-repeat;
  }

  .eyebrow,
  .hero-slider .eyebrow,
  p,
  .lead,
  .card p,
  .text-block p,
  .footer-inner,
  .site-footer {
    color: var(--color-muted);
  }

  .site-footer {
    border-top-color: rgba(255, 250, 242, .12);
  }

  .nav-links {
    background: transparent;
  }

  @media (max-width: 860px) {
    .nav-links {
      border-color: rgba(255, 250, 242, .14);
      background: rgba(38, 51, 68, .98);
      box-shadow: 0 18px 52px rgba(0, 0, 0, .26);
    }
    .nav-links a:hover {
      background: rgba(255, 255, 255, .08);
    }
  }
}

/* NIKARI v58 dashboard-aligned title sizing and dark header correction */
:root {
  --nikari-title-size: clamp(28px, 3.4vw, 44px);
}

h1,
.page-hero h1,
.home-page .home-hero h1,
.hero-slider h1,
.hero-single h1 {
  max-width: 760px !important;
  min-height: auto !important;
  font-family: var(--font) !important;
  font-size: var(--nikari-title-size) !important;
  line-height: 1.08 !important;
  letter-spacing: 0 !important;
  font-weight: 300 !important;
  text-wrap: balance;
}

.hero-slider h1 {
  transition: opacity .38s ease, transform .38s ease, color var(--nikari-transition-theme);
}

strong,
.brand,
.button,
.nav-cta,
.kicker,
.demo-prompt,
.nav-links,
.footer-brand strong,
h2,
h3 {
  font-family: var(--font) !important;
  font-weight: 700;
}

@media (prefers-color-scheme: dark) {
  .home-page .site-header,
  .home-page .site-header.is-scrolled {
    border-bottom-color: rgba(255, 250, 242, .12) !important;
    background: rgba(12, 13, 15, .90) !important;
    box-shadow: none;
  }

  .home-page .site-header.is-scrolled {
    border-color: rgba(255, 250, 242, .18) !important;
    box-shadow: 0 14px 34px rgba(0, 0, 0, .18);
  }

  .home-page .nav-links {
    color: rgba(255, 250, 242, .72);
  }

  .home-page .brand span,
  .home-page .nav-links a:hover,
  .home-page .nav-links a[aria-current="page"] {
    color: #fffaf2 !important;
  }
}

/* NIKARI v59 section titles, gold accents and button contrast */
:root {
  --nikari-title-size: clamp(28px, 3.4vw, 44px);
  --nikari-accent-gold: #dac9a6;
  --nikari-accent-gold-strong: #8c763a;
  --color-accent-red: var(--nikari-accent-gold-strong);
  --color-status-offline: var(--nikari-accent-gold-strong);
  --nikari-red: var(--nikari-accent-gold-strong);
}

.origin-cross {
  background: #b92b24 !important;
}

h1,
.page-hero h1,
.home-page .home-hero h1,
.hero-slider h1,
.hero-single h1,
h2,
.section-heading > h2,
.split-section h2,
.cta-section > h2,
.dark-cta > h2,
.feature-card > h2,
.price-panel .section-heading > h2 {
  max-width: 760px !important;
  min-height: auto !important;
  font-family: var(--font) !important;
  font-size: var(--nikari-title-size) !important;
  line-height: 1.08 !important;
  letter-spacing: 0 !important;
  font-weight: 300 !important;
  text-wrap: balance;
}

.section-heading > h2,
.cta-section > h2,
.dark-cta > h2 {
  margin-left: 0;
  margin-right: 0;
}

.cta-section > h2,
.dark-cta > h2 {
  margin-left: auto !important;
  margin-right: auto !important;
}

.faq-item h2 {
  max-width: none !important;
  font-size: clamp(18px, 1.8vw, 24px) !important;
  line-height: 1.22 !important;
  font-weight: 700 !important;
}

.card h3,
.process-step h3,
.timeline-item h3,
.price-card h3,
.data-room strong,
.price-path-step strong {
  font-family: var(--font) !important;
  font-weight: 700 !important;
}

.eyebrow,
.kicker,
.process-step span,
.timeline-item span,
.price-path-step span,
.price-badge,
.demo-answer-top strong,
.data-room span {
  color: var(--nikari-accent-gold-strong) !important;
}

.eyebrow::before,
.hero-slide-eyebrow::before {
  background: var(--nikari-accent-gold) !important;
  box-shadow: 0 0 0 6px rgba(218, 201, 166, .14) !important;
}

.status-dot {
  background: var(--nikari-accent-gold-strong);
  box-shadow: 0 0 0 6px rgba(218, 201, 166, .14);
}

.hero-visual::after,
.hero-system::after {
  border-color: rgba(218, 201, 166, .24) !important;
}

.hero-system-orbit {
  background: conic-gradient(from 40deg, rgba(218,201,166,0), rgba(218,201,166,.42), rgba(218,201,166,0), rgba(218,201,166,.30), rgba(218,201,166,0)) !important;
}

.flow-process .process-step::after {
  background: linear-gradient(90deg, rgba(218, 201, 166, .18), rgba(218, 201, 166, .85)) !important;
}

.placeholder {
  border-color: rgba(218, 201, 166, .38) !important;
  background: rgba(218, 201, 166, .08) !important;
}

.home-page .home-hero .button.primary,
.dark-cta .button.primary,
.dark-band .button.primary,
.theme-dark .button.primary,
[data-theme="dark"] .button.primary {
  background: #f8f3ed !important;
  border-color: #f8f3ed !important;
  color: #263344 !important;
  text-shadow: none !important;
  box-shadow: 0 16px 42px rgba(0, 0, 0, .24) !important;
}

.home-page .home-hero .button.primary:hover,
.dark-cta .button.primary:hover,
.dark-band .button.primary:hover,
.theme-dark .button.primary:hover,
[data-theme="dark"] .button.primary:hover {
  background: #fffaf2 !important;
  border-color: #fffaf2 !important;
  color: #263344 !important;
}

@media (prefers-color-scheme: dark) {
  .eyebrow,
  .kicker,
  .process-step span,
  .timeline-item span,
  .price-path-step span,
  .price-badge,
  .demo-answer-top strong,
  .data-room span {
    color: var(--nikari-accent-gold) !important;
  }

  .status-dot {
    background: var(--nikari-accent-gold);
    box-shadow: 0 0 0 6px rgba(218, 201, 166, .14);
  }

  .origin-cross {
    background: #b92b24 !important;
  }
}

@media (max-width: 720px) {
  :root {
    --nikari-title-size: clamp(28px, 9vw, 40px);
  }

  h1,
  h2,
  .page-hero h1,
  .home-page .home-hero h1,
  .hero-slider h1,
  .hero-single h1,
  .section-heading > h2,
  .split-section h2,
  .cta-section > h2,
  .dark-cta > h2,
  .feature-card > h2 {
    line-height: 1.12 !important;
  }
}

/* NIKARI v60 simplified footer with Sommer Systems mark */
.footer-inner.footer-inner-simple {
  grid-template-columns: minmax(220px, 1fr) minmax(180px, .8fr) minmax(220px, 1fr);
  align-items: center;
  gap: clamp(22px, 4vw, 56px);
}

.footer-inner-simple .footer-brand {
  max-width: none;
}

.footer-inner-simple .footer-brand span {
  max-width: 340px;
}

.footer-powered {
  display: inline-grid;
  justify-items: center;
  gap: 9px;
  justify-self: center;
  text-align: center;
  color: var(--color-muted);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.2;
  transition: transform .18s ease, color .18s ease;
}

.footer-powered img {
  width: 54px;
  height: 54px;
  object-fit: contain;
  border-radius: 18px;
  box-shadow: 0 14px 34px rgba(0, 0, 0, .14);
}

.footer-powered:hover,
.footer-powered:focus-visible {
  color: var(--color-text);
  transform: translateY(-1px);
}

.footer-inner-simple .footer-contact {
  align-self: center;
}

@media (prefers-color-scheme: dark) {
  .footer-powered {
    color: rgba(255, 250, 242, .72);
  }

  .footer-powered:hover,
  .footer-powered:focus-visible {
    color: #fffaf2;
  }
}

@media (max-width: 820px) {
  .footer-inner.footer-inner-simple {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }

  .footer-inner-simple .footer-brand,
  .footer-inner-simple .footer-brand span,
  .footer-inner-simple .footer-contact {
    justify-items: center;
    text-align: center;
    max-width: 360px;
  }
}

/* NIKARI v61 footer spacing and quieter attribution */
.site-footer {
  padding-top: clamp(70px, 7vw, 104px);
  padding-bottom: clamp(56px, 5.5vw, 82px);
}

.footer-inner.footer-inner-simple {
  width: min(1460px, calc(100% - 96px));
  gap: clamp(42px, 6vw, 92px);
}

.footer-powered {
  font-family: var(--font) !important;
  font-size: 12px;
  font-weight: 300 !important;
  letter-spacing: 0;
  color: color-mix(in srgb, var(--color-muted) 70%, transparent) !important;
}

.footer-powered img {
  opacity: .86;
}

.footer-powered span {
  opacity: .66;
}

.footer-powered:hover span,
.footer-powered:focus-visible span {
  opacity: .86;
}

.footer-inner-simple .footer-contact {
  gap: 10px;
}

@media (prefers-color-scheme: dark) {
  .footer-powered {
    color: rgba(255, 250, 242, .46) !important;
  }

  .footer-powered:hover,
  .footer-powered:focus-visible {
    color: rgba(255, 250, 242, .70) !important;
  }
}

@media (max-width: 820px) {
  .site-footer {
    padding-top: 58px;
    padding-bottom: 52px;
  }

  .footer-inner.footer-inner-simple {
    width: min(100% - 40px, 420px);
    gap: 28px;
  }
}

/* NIKARI v62 final footer text rhythm */
.footer-inner-simple .footer-brand span {
  line-height: 1.42;
}

.footer-contact a[href^="mailto:"] {
  color: var(--color-muted);
  font-weight: 300;
}

.footer-contact a[href^="mailto:"]:hover,
.footer-contact a[href^="mailto:"]:focus-visible {
  color: var(--color-text);
}

@media (prefers-color-scheme: dark) {
  .footer-contact a[href^="mailto:"] {
    color: rgba(255, 250, 242, .62);
  }

  .footer-contact a[href^="mailto:"]:hover,
  .footer-contact a[href^="mailto:"]:focus-visible {
    color: #fffaf2;
  }
}

/* NIKARI v64 dark/light component polish */
@media (prefers-color-scheme: dark) {
  .demo-prompt,
  .demo-answer,
  .pilot-node,
  .price-path-step,
  .price-factor,
  .price-card,
  .compare-table,
  .accordion details,
  .data-room-map,
  .data-room {
    border-color: rgba(255, 250, 242, .16) !important;
    background:
      linear-gradient(145deg, rgba(255, 255, 255, .075), rgba(255, 255, 255, .045)),
      rgba(12, 13, 15, .42) !important;
    color: #fffaf2 !important;
    box-shadow: 0 18px 48px rgba(0, 0, 0, .22) !important;
  }

  .demo-prompt {
    color: rgba(255, 250, 242, .76) !important;
    text-shadow: none !important;
  }

  .demo-prompt:hover,
  .demo-prompt.is-active {
    border-color: rgba(218, 201, 166, .42) !important;
    background:
      linear-gradient(145deg, rgba(218, 201, 166, .16), rgba(255, 255, 255, .075)),
      rgba(12, 13, 15, .54) !important;
    color: #fffaf2 !important;
    box-shadow: 0 16px 42px rgba(0, 0, 0, .28) !important;
  }

  .demo-answer {
    background:
      radial-gradient(circle at top right, rgba(218, 201, 166, .14), transparent 34%),
      linear-gradient(145deg, rgba(255, 255, 255, .085), rgba(255, 255, 255, .045)),
      rgba(12, 13, 15, .50) !important;
  }

  .demo-answer-top {
    color: rgba(218, 201, 166, .76) !important;
  }

  .demo-answer-top strong,
  .source-pills span,
  .data-room span,
  .pilot-node span,
  .price-path-step span,
  .price-badge {
    border-color: rgba(218, 201, 166, .28) !important;
    background: rgba(218, 201, 166, .12) !important;
    color: var(--nikari-accent-gold) !important;
  }

  .demo-question,
  .demo-typing,
  .pilot-node strong,
  .price-path-step strong,
  .price-factor strong,
  .price-card h3,
  .price-value,
  .compare-table [role="row"] > div:first-child,
  .accordion summary {
    color: #fffaf2 !important;
  }

  .demo-typing,
  .pilot-node p,
  .price-path-step p,
  .price-factor p,
  .price-for,
  .fineprint,
  .compare-table [role="row"] > div,
  .accordion details p,
  .check-list {
    color: rgba(255, 250, 242, .76) !important;
  }

  .compare-head,
  .compare-table [role="row"] > div:first-child,
  .accordion summary::after {
    background: rgba(255, 255, 255, .065) !important;
    border-color: rgba(255, 250, 242, .14) !important;
  }

  .compare-table [role="row"],
  .compare-table [role="row"] > div,
  .price-card h3 {
    border-color: rgba(255, 250, 242, .13) !important;
  }

  .price-teaser article {
    border-color: rgba(255, 250, 242, .16) !important;
    background:
      linear-gradient(145deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .045)),
      rgba(12, 13, 15, .44) !important;
    color: #fffaf2 !important;
  }

  .price-teaser span {
    color: var(--nikari-accent-gold) !important;
  }

  .flow-process {
    isolation: isolate;
  }

  .flow-process::before {
    z-index: 0;
    opacity: .34;
    background: linear-gradient(90deg, rgba(218, 201, 166, 0), rgba(218, 201, 166, .58), rgba(218, 201, 166, 0)) !important;
  }

  .flow-process .process-step {
    position: relative;
    z-index: 1;
    border-color: rgba(255, 250, 242, .16) !important;
    background:
      linear-gradient(145deg, rgba(255, 255, 255, .085), rgba(255, 255, 255, .045)),
      rgba(12, 13, 15, .56) !important;
    box-shadow: 0 18px 48px rgba(0, 0, 0, .22) !important;
  }

  .flow-process .process-step span,
  .timeline-item span {
    border-color: rgba(218, 201, 166, .34) !important;
    background: rgba(13, 17, 22, .96) !important;
    color: var(--nikari-accent-gold) !important;
  }

  .flow-process .process-step::after {
    background: linear-gradient(90deg, rgba(218, 201, 166, .18), rgba(218, 201, 166, .78)) !important;
  }

  .note-box,
  .legal-note {
    border-color: rgba(255, 250, 242, .16) !important;
    border-left-color: var(--nikari-accent-gold) !important;
    background: rgba(255, 255, 255, .065) !important;
  }
}

@media (prefers-color-scheme: light) {
  .demo-prompt,
  .demo-answer,
  .price-path-step,
  .pilot-node,
  .price-factor,
  .price-card {
    color: #151515;
  }
}

/* NIKARI v65 hero overlay, process line and footer contact spacing */
.flow-process::before {
  content: none !important;
  display: none !important;
  opacity: 0 !important;
}

.footer-inner-simple .footer-contact {
  gap: 2px !important;
  line-height: 1.18;
}

.footer-inner-simple .footer-contact span,
.footer-inner-simple .footer-contact a[href^="mailto:"],
.footer-inner-simple .footer-contact a[href*="email-protection"] {
  line-height: 1.18;
}

.footer-inner-simple .footer-contact a[href^="mailto:"],
.footer-inner-simple .footer-contact a[href*="email-protection"] {
  margin-top: -2px;
  color: var(--color-muted);
  font-weight: 300;
}

@media (prefers-color-scheme: dark) {
  .home-page .home-hero {
    background:
      linear-gradient(90deg, rgba(4, 5, 7, .66) 0%, rgba(6, 7, 9, .42) 48%, rgba(6, 7, 9, .16) 100%),
      url("/site/images/nikari-hero-lobby.jpg") center / cover no-repeat !important;
  }

  .home-page .home-hero::before {
    display: none !important;
  }

  .footer-inner-simple .footer-contact a[href^="mailto:"],
  .footer-inner-simple .footer-contact a[href*="email-protection"] {
    color: rgba(255, 250, 242, .62) !important;
  }
}

/* NIKARI v66 separate mobile menu from hero overlay */
@media (prefers-color-scheme: dark) {
  .home-page .home-hero {
    background:
      linear-gradient(90deg, rgba(0, 0, 0, .50) 0%, rgba(0, 0, 0, .26) 48%, rgba(0, 0, 0, .08) 100%),
      url("/site/images/nikari-hero-lobby.jpg") center / cover no-repeat !important;
  }

  .site-header,
  .home-page .site-header,
  .home-page .site-header.is-scrolled {
    background: rgba(12, 13, 15, .96) !important;
    border-bottom-color: rgba(255, 250, 242, .14) !important;
  }

  @media (max-width: 1080px) {
    .nav-links,
    .home-page .nav-links {
      z-index: 90;
      background: #0c0d0f !important;
      border-color: rgba(255, 250, 242, .16) !important;
      box-shadow: 0 22px 58px rgba(0, 0, 0, .42) !important;
      backdrop-filter: none !important;
      -webkit-backdrop-filter: none !important;
    }

    .nav-links a,
    .home-page .nav-links a {
      color: rgba(255, 250, 242, .78) !important;
    }

    .nav-links a:hover,
    .nav-links a[aria-current="page"],
    .home-page .nav-links a:hover,
    .home-page .nav-links a[aria-current="page"] {
      background: rgba(255, 255, 255, .07) !important;
      color: #fffaf2 !important;
    }
  }
}

@media (min-width: 1081px) {
  .nav-links {
    position: static !important;
    display: flex !important;
    opacity: 1 !important;
    transform: none !important;
    pointer-events: auto !important;
    padding: 0 !important;
    border: 0 !important;
    box-shadow: none !important;
    background: transparent !important;
  }
}

/* v71: soft blue hero veil, single layer only. */
@media (prefers-color-scheme: dark) {
  .home-page .home-hero {
    background:
      linear-gradient(90deg, rgba(38, 51, 68, .30) 0%, rgba(38, 51, 68, .18) 48%, rgba(38, 51, 68, .08) 100%),
      url("/site/images/nikari-hero-lobby.jpg") center / cover no-repeat !important;
  }

  .home-page .home-hero::before,
  .home-page .home-hero::after {
    content: none !important;
    display: none !important;
    background: none !important;
  }

  .home-page .home-hero .hero-slider-bg {
    display: none !important;
    background: none !important;
  }
}

/* v72: visible mobile menu label. */
@media (max-width: 1080px) {
  .nav-toggle {
    display: inline-grid !important;
    grid-template-columns: 22px auto;
    align-items: center;
    justify-content: center;
    column-gap: 10px;
    width: auto !important;
    min-width: 98px;
    height: 56px;
    padding: 0 18px;
    flex-direction: initial !important;
    gap: 0;
  }

  .nav-toggle::after {
    content: "Menü";
    grid-column: 2;
    grid-row: 1;
    color: currentColor;
    font-size: 17px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0;
  }

  .nav-toggle span {
    grid-column: 1;
    grid-row: 1;
    justify-self: center;
    width: 20px;
    height: 2px;
    background: currentColor;
  }

  .nav-toggle span:first-child {
    transform: translateY(-4px);
  }

  .nav-toggle span:last-child {
    transform: translateY(4px);
  }

  .nav-toggle[aria-expanded="true"] span:first-child {
    transform: rotate(45deg);
  }

  .nav-toggle[aria-expanded="true"] span:last-child {
    transform: rotate(-45deg);
  }
}

@media (max-width: 420px) {
  .nav {
    gap: 16px;
  }

  .nav-toggle {
    min-width: 88px;
    height: 52px;
    padding: 0 14px;
    column-gap: 8px;
  }

  .nav-toggle::after {
    font-size: 15px;
  }
}

/* v73: fix mobile menu icon/text spacing. */
@media (max-width: 1080px) {
  .nav-toggle {
    grid-template-columns: 24px auto;
    min-width: 116px;
    padding: 0 22px;
    column-gap: 14px !important;
    gap: 0 14px !important;
    place-items: center;
  }

  .nav-toggle span {
    width: 22px;
    border-radius: 999px;
  }
}

@media (max-width: 420px) {
  .nav-toggle {
    min-width: 104px;
    padding: 0 16px;
    column-gap: 10px !important;
    gap: 0 10px !important;
  }
}

/* v74: prevent iOS from tinting the mobile menu button blue. */
@media (max-width: 1080px) {
  .nav-toggle {
    color: #151515 !important;
    -webkit-text-fill-color: #151515;
  }
}

@media (prefers-color-scheme: dark) and (max-width: 1080px) {
  .nav-toggle {
    color: #fffaf2 !important;
    -webkit-text-fill-color: #fffaf2;
  }
}

/* v76: give the desktop navigation more breathing room. */
@media (min-width: 1081px) {
  .nav {
    gap: 20px;
  }

  .nav-links {
    gap: clamp(18px, 1.3vw, 24px) !important;
  }
}

/* v75: mobile menu is a transparent text control, not a visual button. */
@media (max-width: 1080px) {
  .nav-toggle {
    min-width: auto;
    width: auto !important;
    height: 44px;
    padding: 0 2px;
    border: 0 !important;
    border-radius: 0;
    background: transparent !important;
    box-shadow: none !important;
    color: #151515 !important;
    -webkit-tap-highlight-color: transparent;
    -webkit-text-fill-color: #151515;
  }

  .nav-toggle:hover,
  .nav-toggle:focus-visible {
    background: transparent !important;
    box-shadow: none !important;
  }

  .nav-toggle:focus-visible {
    outline: 2px solid rgba(38, 51, 68, .34);
    outline-offset: 5px;
    border-radius: 6px;
  }
}

@media (prefers-color-scheme: dark) and (max-width: 1080px) {
  .nav-toggle {
    color: #fffaf2 !important;
    -webkit-text-fill-color: #fffaf2;
  }
}

/* NIKARI v77 compact footer correction */
.site-footer {
  padding-top: 44px !important;
  padding-bottom: 34px !important;
}

.footer-inner.footer-inner-simple {
  width: min(var(--max), calc(100% - 32px)) !important;
  display: grid !important;
  grid-template-columns: minmax(220px, 1fr) minmax(120px, auto) minmax(220px, 1fr) !important;
  align-items: center !important;
  gap: clamp(22px, 4vw, 54px) !important;
}

.footer-inner-simple .footer-brand {
  display: grid !important;
  justify-items: start !important;
  gap: 6px !important;
  max-width: none !important;
  text-align: left !important;
}

.footer-inner-simple .footer-brand strong {
  color: var(--color-text) !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  letter-spacing: .18em !important;
  line-height: 1 !important;
}

.footer-inner-simple .footer-brand span {
  max-width: 310px !important;
  color: var(--color-muted) !important;
  font-size: 16px !important;
  font-weight: 300 !important;
  line-height: 1.35 !important;
  letter-spacing: 0 !important;
}

.footer-powered {
  gap: 7px !important;
  color: color-mix(in srgb, var(--color-muted) 70%, transparent) !important;
  font-size: 12px !important;
  font-weight: 300 !important;
  line-height: 1.2 !important;
  transform: none !important;
}

.footer-powered img {
  width: 52px !important;
  height: 52px !important;
  object-fit: contain !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  filter: none !important;
  opacity: .9 !important;
}

.footer-powered:hover,
.footer-powered:focus-visible {
  transform: none !important;
}

.footer-inner-simple .footer-contact {
  display: grid !important;
  justify-items: end !important;
  gap: 3px !important;
  text-align: right !important;
  line-height: 1.18 !important;
}

.footer-inner-simple .footer-contact > a:first-child {
  color: var(--color-text) !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  line-height: 1.18 !important;
}

.footer-inner-simple .footer-contact > span {
  color: var(--color-text) !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  line-height: 1.18 !important;
}

.footer-inner-simple .footer-contact a[href^="mailto:"],
.footer-inner-simple .footer-contact a[href*="email-protection"] {
  margin-top: 0 !important;
  color: var(--color-muted) !important;
  font-size: 16px !important;
  font-weight: 300 !important;
  line-height: 1.18 !important;
  overflow-wrap: anywhere;
}

@media (prefers-color-scheme: dark) {
  .footer-inner-simple .footer-brand span,
  .footer-inner-simple .footer-contact a[href^="mailto:"],
  .footer-inner-simple .footer-contact a[href*="email-protection"] {
    color: rgba(255, 250, 242, .62) !important;
  }
}

@media (max-width: 820px) {
  .site-footer {
    padding-top: 38px !important;
    padding-bottom: 36px !important;
  }

  .footer-inner.footer-inner-simple {
    width: min(100% - 34px, 390px) !important;
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    gap: 20px !important;
    text-align: center !important;
  }

  .footer-inner-simple .footer-brand,
  .footer-inner-simple .footer-contact {
    justify-items: center !important;
    text-align: center !important;
  }

  .footer-inner-simple .footer-brand {
    gap: 7px !important;
  }

  .footer-inner-simple .footer-brand strong {
    font-size: 16px !important;
    letter-spacing: .20em !important;
  }

  .footer-inner-simple .footer-brand span {
    max-width: 330px !important;
    font-size: 17px !important;
    line-height: 1.34 !important;
  }

  .footer-powered {
    gap: 7px !important;
    font-size: 13px !important;
  }

  .footer-powered img {
    width: 56px !important;
    height: 56px !important;
  }

  .footer-inner-simple .footer-contact {
    gap: 4px !important;
  }

  .footer-inner-simple .footer-contact > a:first-child,
  .footer-inner-simple .footer-contact > span {
    font-size: 17px !important;
  }

  .footer-inner-simple .footer-contact a[href^="mailto:"],
  .footer-inner-simple .footer-contact a[href*="email-protection"] {
    font-size: 16px !important;
  }
}

/* NIKARI v78 quieter footer contact */
.footer-inner-simple .footer-contact {
  display: grid !important;
  justify-items: end !important;
  gap: 5px !important;
  text-align: right !important;
  line-height: 1.28 !important;
}

.footer-inner-simple .footer-contact > a:first-child {
  color: var(--color-text) !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  line-height: 1.28 !important;
}

.footer-inner-simple .footer-contact > span {
  color: var(--color-text) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 1.28 !important;
}

.footer-inner-simple .footer-contact a[href^="mailto:"],
.footer-inner-simple .footer-contact a[href*="email-protection"] {
  margin-top: 0 !important;
  color: var(--color-muted) !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  line-height: 1.28 !important;
  overflow-wrap: anywhere;
}

@media (prefers-color-scheme: dark) {
  .footer-inner-simple .footer-contact > a:first-child,
  .footer-inner-simple .footer-contact > span {
    color: #fffaf2 !important;
  }

  .footer-inner-simple .footer-contact a[href^="mailto:"],
  .footer-inner-simple .footer-contact a[href*="email-protection"] {
    color: rgba(255, 250, 242, .62) !important;
  }
}

@media (max-width: 820px) {
  .footer-inner-simple .footer-contact {
    justify-items: center !important;
    gap: 6px !important;
    text-align: center !important;
  }

  .footer-inner-simple .footer-contact > a:first-child {
    font-size: 16px !important;
    font-weight: 400 !important;
  }

  .footer-inner-simple .footer-contact > span {
    font-size: 17px !important;
    font-weight: 400 !important;
  }

  .footer-inner-simple .footer-contact a[href^="mailto:"],
  .footer-inner-simple .footer-contact a[href*="email-protection"] {
    font-size: 16px !important;
    font-weight: 300 !important;
  }
}

/* v79: wider desktop navigation and clearer live-system status copy. */
@media (min-width: 1081px) {
  .nav-links {
    gap: 25px !important;
  }
}

.system-status-badge,
.system-status-badge [data-status-label] {
  text-transform: none !important;
}

/* NIKARI v84 polished footer icons */
.footer-inner.footer-inner-simple {
  align-items: center !important;
  gap: clamp(28px, 4.6vw, 72px) !important;
}

.footer-inner-simple .footer-contact {
  display: grid !important;
  justify-self: end !important;
  justify-items: start !important;
  align-self: center !important;
  width: auto !important;
  max-width: 390px !important;
  gap: 9px !important;
  padding: 0 0 0 18px !important;
  border: 0 !important;
  border-left: 1px solid rgba(38, 51, 68, .20) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--color-text) !important;
  text-align: left !important;
  line-height: 1.2 !important;
}

.footer-inner-simple .footer-contact > .footer-contact-title {
  margin: 0 !important;
  max-width: none !important;
  color: rgba(21, 21, 21, .72) !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.2 !important;
}

.footer-socials {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 9px !important;
}

.footer-social-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  min-height: 38px !important;
  padding: 0 12px 0 7px !important;
  border: 1px solid rgba(38, 51, 68, .18) !important;
  border-radius: 999px !important;
  background: rgba(38, 51, 68, .045) !important;
  color: #263344 !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  transition: background .16s ease, border-color .16s ease, transform .16s ease, color .16s ease !important;
}

.footer-social-icon {
  display: inline-grid !important;
  place-items: center !important;
  width: 26px !important;
  height: 26px !important;
  border-radius: 999px !important;
  background: #263344 !important;
  color: #fffaf2 !important;
  flex: 0 0 26px !important;
}

.footer-social-link-whatsapp .footer-social-icon {
  background: #25d366 !important;
  color: #fff !important;
}

.footer-social-icon svg {
  display: block !important;
  width: 15px !important;
  height: 15px !important;
  fill: none !important;
  stroke: currentColor !important;
  stroke-width: 1.9 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

.footer-social-link-whatsapp .footer-social-icon svg {
  width: 15px !important;
  height: 15px !important;
  fill: currentColor !important;
  stroke: none !important;
}

.footer-social-link:hover,
.footer-social-link:focus-visible {
  border-color: rgba(38, 51, 68, .34) !important;
  background: rgba(38, 51, 68, .08) !important;
  color: #151515 !important;
  transform: translateY(-1px) !important;
}

@media (prefers-color-scheme: dark) {
  .footer-inner-simple .footer-contact {
    border-left-color: rgba(255, 250, 242, .20) !important;
    color: #fffaf2 !important;
  }

  .footer-inner-simple .footer-contact > .footer-contact-title {
    color: rgba(255, 250, 242, .68) !important;
  }

  .footer-social-link {
    border-color: rgba(255, 250, 242, .18) !important;
    background: rgba(255, 250, 242, .055) !important;
    color: rgba(255, 250, 242, .88) !important;
  }

  .footer-social-icon {
    background: #fffaf2 !important;
    color: #263344 !important;
  }

  .footer-social-link-whatsapp .footer-social-icon {
    background: #25d366 !important;
    color: #fff !important;
  }

  .footer-social-link:hover,
  .footer-social-link:focus-visible {
    border-color: rgba(255, 250, 242, .32) !important;
    background: rgba(255, 250, 242, .095) !important;
    color: #fffaf2 !important;
  }
}

@media (max-width: 820px) {
  .site-footer {
    padding-top: 58px !important;
    padding-bottom: 58px !important;
  }

  .footer-inner.footer-inner-simple {
    gap: 36px !important;
  }

  .footer-inner-simple .footer-contact {
    justify-self: center !important;
    justify-items: center !important;
    width: min(100%, 360px) !important;
    max-width: 360px !important;
    gap: 15px !important;
    padding: 24px 0 0 !important;
    border-left: 0 !important;
    border-top: 1px solid rgba(38, 51, 68, .16) !important;
    text-align: center !important;
  }

  .footer-inner-simple .footer-contact > .footer-contact-title {
    font-size: 15px !important;
  }

  .footer-socials {
    justify-content: center !important;
    gap: 12px 10px !important;
  }

  .footer-social-link {
    min-height: 38px !important;
    padding: 0 12px 0 7px !important;
    font-size: 13px !important;
  }
}

/* NIKARI v85 neutral WhatsApp footer icon */
.footer-social-link-whatsapp .footer-social-icon {
  background: #263344 !important;
  color: #fffaf2 !important;
}

@media (prefers-color-scheme: dark) {
  .footer-social-link-whatsapp .footer-social-icon {
    background: #fffaf2 !important;
    color: #263344 !important;
  }
}

/* NIKARI v86 footer social color hardening */
.footer-inner-simple .footer-contact .footer-social-link,
.footer-inner-simple .footer-contact .footer-social-link-mail[href^="mailto:"],
.footer-inner-simple .footer-contact .footer-social-link-mail[href*="email-protection"] {
  color: #263344 !important;
}

.footer-social-link > span:not(.footer-social-icon) {
  color: currentColor !important;
  opacity: 1 !important;
}

.footer-social-link-whatsapp .footer-social-icon {
  background: #263344 !important;
  color: #fffaf2 !important;
}

@media (prefers-color-scheme: dark) {
  .footer-inner-simple .footer-contact .footer-social-link,
  .footer-inner-simple .footer-contact .footer-social-link-mail[href^="mailto:"],
  .footer-inner-simple .footer-contact .footer-social-link-mail[href*="email-protection"] {
    color: rgba(255, 250, 242, .88) !important;
  }

  .footer-social-link-whatsapp .footer-social-icon {
    background: #fffaf2 !important;
    color: #263344 !important;
  }
}

/* NIKARI v87 compact footer social icons */
.footer-socials {
  gap: 8px !important;
}

.footer-social-link {
  gap: 6px !important;
  min-height: 32px !important;
  padding: 0 10px 0 6px !important;
  font-size: 13px !important;
}

.footer-social-icon {
  width: 22px !important;
  height: 22px !important;
  flex-basis: 22px !important;
}

.footer-social-icon svg,
.footer-social-link-whatsapp .footer-social-icon svg {
  width: 12.5px !important;
  height: 12.5px !important;
}

.footer-inner-simple .footer-contact .footer-socials .footer-social-link,
.footer-inner-simple .footer-contact .footer-socials .footer-social-link:link,
.footer-inner-simple .footer-contact .footer-socials .footer-social-link:visited,
.footer-inner-simple .footer-contact .footer-socials .footer-social-link-mail[href^="mailto:"],
.footer-inner-simple .footer-contact .footer-socials .footer-social-link-mail[href*="email-protection"] {
  color: #263344 !important;
}

.footer-inner-simple .footer-contact .footer-socials .footer-social-link > span:not(.footer-social-icon) {
  color: #263344 !important;
  opacity: 1 !important;
}

.footer-social-link-whatsapp .footer-social-icon {
  background: #263344 !important;
  color: #fffaf2 !important;
}

@media (prefers-color-scheme: dark) {
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link:link,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link:visited,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link-mail[href^="mailto:"],
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link-mail[href*="email-protection"] {
    color: rgba(255, 250, 242, .88) !important;
  }

  .footer-inner-simple .footer-contact .footer-socials .footer-social-link > span:not(.footer-social-icon) {
    color: rgba(255, 250, 242, .88) !important;
    opacity: 1 !important;
  }

  .footer-social-link-whatsapp .footer-social-icon {
    background: #fffaf2 !important;
    color: #263344 !important;
  }
}

@media (max-width: 820px) {
  .footer-socials {
    gap: 11px 8px !important;
  }

  .footer-social-link {
    min-height: 33px !important;
    padding: 0 10px 0 6px !important;
    font-size: 12.5px !important;
  }
}

/* NIKARI v88 equal compact footer social links */
.footer-inner-simple .footer-contact .footer-socials .footer-social-link,
.footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"],
.footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] {
  gap: 6px !important;
  min-height: 31px !important;
  padding: 0 9px 0 6px !important;
  color: #263344 !important;
  font-size: 12.5px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
}

.footer-inner-simple .footer-contact .footer-socials .footer-social-link > span:not(.footer-social-icon),
.footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"] > span:not(.footer-social-icon),
.footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] > span:not(.footer-social-icon) {
  color: #263344 !important;
  font-size: 12.5px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
  opacity: 1 !important;
}

.footer-social-icon {
  width: 21px !important;
  height: 21px !important;
  flex-basis: 21px !important;
}

.footer-social-icon svg,
.footer-social-link-whatsapp .footer-social-icon svg {
  width: 12px !important;
  height: 12px !important;
}

@media (prefers-color-scheme: dark) {
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"],
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] {
    color: rgba(255, 250, 242, .88) !important;
  }

  .footer-inner-simple .footer-contact .footer-socials .footer-social-link > span:not(.footer-social-icon),
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"] > span:not(.footer-social-icon),
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] > span:not(.footer-social-icon) {
    color: rgba(255, 250, 242, .88) !important;
  }
}

@media (max-width: 820px) {
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"],
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] {
    min-height: 32px !important;
    padding: 0 9px 0 6px !important;
    font-size: 12px !important;
  }

  .footer-inner-simple .footer-contact .footer-socials .footer-social-link > span:not(.footer-social-icon),
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"] > span:not(.footer-social-icon),
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] > span:not(.footer-social-icon) {
    font-size: 12px !important;
  }
}

/* NIKARI v89 smaller equal footer social links */
.footer-inner-simple .footer-contact .footer-socials {
  gap: 7px !important;
  align-items: center !important;
}

.footer-inner-simple .footer-contact .footer-socials .footer-social-link,
.footer-inner-simple .footer-contact .footer-socials .footer-social-link:link,
.footer-inner-simple .footer-contact .footer-socials .footer-social-link:visited,
.footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"],
.footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] {
  gap: 6px !important;
  min-height: 28px !important;
  padding: 0 8px 0 5px !important;
  border-radius: 999px !important;
  color: #263344 !important;
  font-size: 11.5px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
}

.footer-inner-simple .footer-contact .footer-socials .footer-social-link > span:not(.footer-social-icon),
.footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"] > span:not(.footer-social-icon),
.footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] > span:not(.footer-social-icon) {
  display: inline-block !important;
  color: #263344 !important;
  font-size: 11.5px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  opacity: 1 !important;
}

.footer-inner-simple .footer-contact .footer-socials .footer-social-icon {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
}

.footer-inner-simple .footer-contact .footer-socials .footer-social-icon svg,
.footer-inner-simple .footer-contact .footer-socials .footer-social-link-whatsapp .footer-social-icon svg {
  width: 10.5px !important;
  height: 10.5px !important;
}

@media (max-width: 720px) {
  .footer-inner-simple .footer-contact .footer-socials {
    gap: 8px !important;
    row-gap: 10px !important;
  }

  .footer-inner-simple .footer-contact .footer-socials .footer-social-link,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link:link,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link:visited,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"],
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] {
    min-height: 30px !important;
    padding: 0 9px 0 6px !important;
    font-size: 11.5px !important;
  }

  .footer-inner-simple .footer-contact .footer-socials .footer-social-link > span:not(.footer-social-icon),
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"] > span:not(.footer-social-icon),
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] > span:not(.footer-social-icon) {
    font-size: 11.5px !important;
  }
}

/* NIKARI v90 final compact footer social links */
.footer-inner-simple .footer-contact .footer-socials .footer-social-link,
.footer-inner-simple .footer-contact .footer-socials .footer-social-link:link,
.footer-inner-simple .footer-contact .footer-socials .footer-social-link:visited,
.footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"],
.footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] {
  gap: 5.5px !important;
  min-height: 28px !important;
  padding: 0 8px 0 5px !important;
  color: #263344 !important;
  font-size: 11.25px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
}

.footer-inner-simple .footer-contact .footer-socials .footer-social-link > span:not(.footer-social-icon),
.footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"] > span:not(.footer-social-icon),
.footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] > span:not(.footer-social-icon) {
  color: #263344 !important;
  font-size: 11.25px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  opacity: 1 !important;
}

.footer-inner-simple .footer-contact .footer-socials .footer-social-icon {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  max-width: 18px !important;
  flex: 0 0 18px !important;
  flex-basis: 18px !important;
}

.footer-inner-simple .footer-contact .footer-socials .footer-social-icon svg,
.footer-inner-simple .footer-contact .footer-socials .footer-social-link-whatsapp .footer-social-icon svg {
  width: 10px !important;
  height: 10px !important;
}

@media (max-width: 720px) {
  .footer-inner-simple .footer-contact .footer-socials {
    row-gap: 11px !important;
  }

  .footer-inner-simple .footer-contact .footer-socials .footer-social-link,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link:link,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link:visited,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"],
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] {
    min-height: 29px !important;
    font-size: 11.25px !important;
  }

  .footer-inner-simple .footer-contact .footer-socials .footer-social-link > span:not(.footer-social-icon),
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"] > span:not(.footer-social-icon),
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] > span:not(.footer-social-icon) {
    font-size: 11.25px !important;
  }
}

/* NIKARI v83 warm start-page price section */
.home-page .price-start-section {
  position: relative;
  overflow: hidden;
  border-top-color: rgba(218, 201, 166, .34) !important;
  border-bottom-color: rgba(218, 201, 166, .28) !important;
  background:
    linear-gradient(135deg, rgba(248, 243, 237, .98) 0%, rgba(255, 250, 242, .96) 48%, rgba(218, 201, 166, .22) 100%),
    repeating-linear-gradient(90deg, rgba(38, 51, 68, .045) 0 1px, transparent 1px 88px) !important;
}

.home-page .price-start-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(38, 51, 68, .075), transparent 24%, transparent 76%, rgba(218, 201, 166, .16)),
    linear-gradient(180deg, rgba(255, 250, 242, .72), transparent 42%);
}

.home-page .price-start-section > .section {
  position: relative;
  z-index: 1;
}

.home-page .price-start-section .section-heading {
  max-width: 850px;
}

.home-page .price-start-section .price-path {
  position: relative;
  gap: 22px;
  margin-top: 32px;
  margin-bottom: 26px;
}

.home-page .price-start-section .price-path::before {
  content: "";
  position: absolute;
  z-index: 0;
  left: 9%;
  right: 9%;
  top: 51px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(218, 201, 166, 0), rgba(218, 201, 166, .92), rgba(38, 51, 68, .34), rgba(218, 201, 166, 0));
}

.home-page .price-start-section .price-path-step {
  position: relative;
  z-index: 1;
  min-height: 188px;
  padding: 26px 24px;
  border-color: rgba(218, 201, 166, .46) !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, .90), rgba(255, 250, 242, .70)),
    rgba(255, 255, 255, .72) !important;
  box-shadow: 0 18px 50px rgba(38, 51, 68, .075), inset 0 1px 0 rgba(255, 255, 255, .92) !important;
}

.home-page .price-start-section .price-path-step::before {
  content: "";
  position: absolute;
  right: 22px;
  bottom: 20px;
  width: 68px;
  height: 68px;
  border: 1px solid rgba(218, 201, 166, .34);
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(218, 201, 166, .24), rgba(255, 255, 255, .10)),
    rgba(38, 51, 68, .035);
  transform: rotate(-5deg);
}

.home-page .price-start-section .price-path-step:nth-child(2)::before {
  border-radius: 999px;
  transform: rotate(4deg);
}

.home-page .price-start-section .price-path-step:nth-child(3)::before {
  border-radius: 14px 999px 999px 14px;
  transform: rotate(7deg);
}

.home-page .price-start-section .price-path-step span {
  position: relative;
  z-index: 1;
  border: 1px solid rgba(218, 201, 166, .42);
  background: rgba(255, 250, 242, .92) !important;
  color: #263344 !important;
}

.home-page .price-start-section .price-path-step strong,
.home-page .price-start-section .price-path-step p {
  position: relative;
  z-index: 1;
}

.home-page .price-start-section .price-teaser {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.home-page .price-start-section .price-teaser article {
  position: relative;
  min-height: 134px;
  padding: 22px 20px 20px;
  border-color: rgba(38, 51, 68, .12) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .86), rgba(255, 250, 242, .68)),
    rgba(255, 255, 255, .72) !important;
  box-shadow: 0 14px 34px rgba(38, 51, 68, .055);
}

.home-page .price-start-section .price-teaser article::before {
  content: "";
  position: absolute;
  left: 0;
  top: 18px;
  bottom: 18px;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(180deg, #dac9a6, rgba(38, 51, 68, .38));
}

.home-page .price-start-section .price-teaser article:first-child {
  border-color: rgba(38, 51, 68, .22) !important;
  background:
    linear-gradient(145deg, rgba(38, 51, 68, .96), rgba(23, 28, 35, .94)),
    #263344 !important;
  color: #fffaf2 !important;
}

.home-page .price-start-section .price-teaser article:first-child strong {
  color: #fffaf2 !important;
}

.home-page .price-start-section .price-teaser article:first-child span {
  color: #dac9a6 !important;
}

.home-page .price-start-section .price-teaser strong {
  color: #151515;
  font-size: 15px;
}

.home-page .price-start-section .price-teaser span {
  margin-top: 10px;
  color: #263344;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.24;
}

.home-page .price-start-section .actions {
  margin-top: 30px;
}

@media (prefers-color-scheme: dark) {
  .home-page .price-start-section {
    border-top-color: rgba(218, 201, 166, .20) !important;
    border-bottom-color: rgba(218, 201, 166, .16) !important;
    background:
      linear-gradient(135deg, #0c0d0f 0%, #151b23 46%, #263344 100%),
      repeating-linear-gradient(90deg, rgba(255, 250, 242, .035) 0 1px, transparent 1px 88px) !important;
  }

  .home-page .price-start-section::before {
    background:
      linear-gradient(90deg, rgba(218, 201, 166, .12), transparent 28%, transparent 72%, rgba(0, 0, 0, .20)),
      linear-gradient(180deg, rgba(0, 0, 0, .22), transparent 48%);
  }

  .home-page .price-start-section .price-path::before {
    background: linear-gradient(90deg, rgba(218, 201, 166, 0), rgba(218, 201, 166, .72), rgba(255, 250, 242, .20), rgba(218, 201, 166, 0));
  }

  .home-page .price-start-section .price-path-step {
    border-color: rgba(218, 201, 166, .24) !important;
    background:
      linear-gradient(145deg, rgba(255, 250, 242, .09), rgba(255, 250, 242, .045)),
      rgba(12, 13, 15, .48) !important;
    box-shadow: 0 18px 48px rgba(0, 0, 0, .24), inset 0 1px 0 rgba(255, 250, 242, .06) !important;
  }

  .home-page .price-start-section .price-path-step::before {
    border-color: rgba(218, 201, 166, .24);
    background:
      linear-gradient(135deg, rgba(218, 201, 166, .16), rgba(255, 250, 242, .04)),
      rgba(255, 250, 242, .035);
  }

  .home-page .price-start-section .price-teaser article {
    border-color: rgba(218, 201, 166, .18) !important;
    background:
      linear-gradient(145deg, rgba(255, 250, 242, .08), rgba(255, 250, 242, .04)),
      rgba(12, 13, 15, .46) !important;
    box-shadow: 0 18px 48px rgba(0, 0, 0, .22);
  }

  .home-page .price-start-section .price-teaser strong {
    color: #fffaf2 !important;
  }

  .home-page .price-start-section .price-teaser span {
    color: #dac9a6 !important;
  }
}

@media (max-width: 1024px) {
  .home-page .price-start-section .price-teaser {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .home-page .price-start-section .price-path::before {
    display: none;
  }

  .home-page .price-start-section .price-path,
  .home-page .price-start-section .price-teaser {
    grid-template-columns: 1fr;
  }

  .home-page .price-start-section .price-path-step,
  .home-page .price-start-section .price-teaser article {
    min-height: auto;
  }
}

/* NIKARI v168 start page stage pricing */
.home-page .price-start-section .stage-price-teaser {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
  margin-top: 34px;
}

.home-page .price-start-section .stage-price-teaser article {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 214px;
  padding: 26px 22px 22px;
}

.home-page .price-start-section .stage-price-teaser article:first-child {
  border-color: rgba(38, 51, 68, .12) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .86), rgba(255, 250, 242, .68)),
    rgba(255, 255, 255, .72) !important;
  color: #151515 !important;
}

.home-page .price-start-section .stage-price-teaser article:first-child strong {
  color: #151515 !important;
}

.home-page .price-start-section .stage-price-teaser article:first-child span {
  color: #263344 !important;
}

.home-page .price-start-section .stage-price-teaser article.is-recommended {
  border-color: rgba(218, 201, 166, .62) !important;
  background:
    linear-gradient(145deg, rgba(38, 51, 68, .96), rgba(23, 28, 35, .94)),
    #263344 !important;
  color: #fffaf2 !important;
  box-shadow: 0 22px 54px rgba(38, 51, 68, .18);
}

.home-page .price-start-section .stage-price-teaser article.is-recommended strong,
.home-page .price-start-section .stage-price-teaser article.is-recommended p,
.home-page .price-start-section .stage-price-teaser article.is-recommended small {
  color: #fffaf2 !important;
}

.home-page .price-start-section .stage-price-teaser article.is-recommended span {
  color: #dac9a6 !important;
}

.home-page .price-start-section .stage-price-teaser strong {
  padding-right: 96px;
  font-size: 18px;
  line-height: 1.2;
}

.home-page .price-start-section .stage-price-teaser span {
  margin-top: 0;
  max-width: none;
  font-size: clamp(19px, 1.7vw, 23px);
  line-height: 1.18;
}

.home-page .price-start-section .stage-price-teaser p,
.home-page .price-start-section .stage-price-teaser small {
  position: relative;
  z-index: 1;
  margin: 0;
  line-height: 1.4;
}

.home-page .price-start-section .stage-price-teaser p {
  color: rgba(38, 51, 68, .78);
  font-size: 15px;
  font-weight: 780;
}

.home-page .price-start-section .stage-price-teaser small {
  margin-top: auto;
  color: rgba(21, 21, 21, .78);
  font-size: 14px;
  font-weight: 650;
}

.home-page .price-start-section .stage-price-teaser .stage-badge {
  position: absolute;
  z-index: 2;
  top: 16px;
  right: 16px;
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 12px;
  border: 1px solid rgba(218, 201, 166, .52);
  border-radius: 999px;
  background: rgba(255, 250, 242, .10);
  color: #dac9a6;
  font-size: 13px;
  line-height: 1;
}

@media (prefers-color-scheme: dark) {
  .home-page .price-start-section .stage-price-teaser article:first-child {
    border-color: rgba(218, 201, 166, .18) !important;
    background:
      linear-gradient(145deg, rgba(255, 250, 242, .08), rgba(255, 250, 242, .04)),
      rgba(12, 13, 15, .46) !important;
    color: #fffaf2 !important;
  }

  .home-page .price-start-section .stage-price-teaser article:first-child strong,
  .home-page .price-start-section .stage-price-teaser article:first-child p,
  .home-page .price-start-section .stage-price-teaser article:first-child small {
    color: #fffaf2 !important;
  }

  .home-page .price-start-section .stage-price-teaser article:first-child span {
    color: #dac9a6 !important;
  }

  .home-page .price-start-section .stage-price-teaser article.is-recommended {
    border-color: rgba(218, 201, 166, .54) !important;
    background:
      linear-gradient(145deg, rgba(218, 201, 166, .18), rgba(38, 51, 68, .86)),
      #151b23 !important;
  }
}

@media (max-width: 1040px) {
  .home-page .price-start-section .stage-price-teaser {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .home-page .price-start-section .stage-price-teaser span {
    font-size: 20px;
  }
}

@media (max-width: 900px) {
  .home-page .price-start-section .stage-price-teaser {
    grid-template-columns: 1fr;
  }

  .home-page .price-start-section .stage-price-teaser article {
    min-height: 188px;
  }
}

/* NIKARI v169 clearer live status pulse */
.status-dot {
  position: relative;
  flex: 0 0 auto;
}

.system-status-badge.is-online .status-dot {
  width: 11px;
  height: 11px;
  box-shadow: 0 0 0 5px rgba(33, 133, 83, .18), 0 0 18px rgba(33, 133, 83, .22);
  animation: statusPulseClear 1.9s ease-in-out infinite;
}

.system-status-badge.is-online .status-dot::after {
  content: "";
  position: absolute;
  inset: -7px;
  border: 1px solid rgba(33, 133, 83, .28);
  border-radius: 999px;
  opacity: .82;
  transform: scale(.74);
  animation: statusHaloClear 1.9s ease-out infinite;
}

.home-page .home-hero .system-status-badge.is-online .status-dot {
  box-shadow: 0 0 0 5px rgba(255, 255, 255, .23), 0 0 22px rgba(255, 255, 255, .22);
  animation-name: statusPulseHeroClear;
}

.home-page .home-hero .system-status-badge.is-online .status-dot::after {
  border-color: rgba(255, 255, 255, .42);
}

@keyframes statusPulseClear {
  0%, 100% {
    box-shadow: 0 0 0 5px rgba(33, 133, 83, .18), 0 0 18px rgba(33, 133, 83, .22);
  }
  50% {
    box-shadow: 0 0 0 10px rgba(33, 133, 83, .08), 0 0 26px rgba(33, 133, 83, .30);
  }
}

@keyframes statusPulseHeroClear {
  0%, 100% {
    box-shadow: 0 0 0 5px rgba(255, 255, 255, .23), 0 0 22px rgba(255, 255, 255, .22);
  }
  50% {
    box-shadow: 0 0 0 11px rgba(255, 255, 255, .11), 0 0 30px rgba(255, 255, 255, .30);
  }
}

@keyframes statusHaloClear {
  0% {
    opacity: .82;
    transform: scale(.74);
  }
  70%, 100% {
    opacity: 0;
    transform: scale(1.45);
  }
}

/* NIKARI v93 dark mode browser edge and footer social text */
@media (prefers-color-scheme: dark) {
  html {
    background-color: #263344 !important;
  }

  body {
    background-color: #263344 !important;
  }

  .footer-inner-simple .footer-contact > .footer-contact-title {
    color: rgba(255, 250, 242, .74) !important;
  }

  .footer-inner-simple .footer-contact .footer-socials .footer-social-link,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link:link,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link:visited,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"],
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] {
    border-color: rgba(255, 250, 242, .26) !important;
    background: rgba(255, 250, 242, .055) !important;
    color: rgba(255, 250, 242, .86) !important;
    font-size: 11.25px !important;
    font-weight: 400 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
  }

  .footer-inner-simple .footer-contact .footer-socials .footer-social-link > span:not(.footer-social-icon),
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href^="mailto:"] > span:not(.footer-social-icon),
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link[href*="email-protection"] > span:not(.footer-social-icon) {
    color: rgba(255, 250, 242, .86) !important;
    font-size: 11.25px !important;
    font-weight: 400 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    opacity: 1 !important;
  }

  .footer-inner-simple .footer-contact .footer-socials .footer-social-icon {
    background: #fffaf2 !important;
    color: #263344 !important;
  }

  .footer-inner-simple .footer-contact .footer-socials .footer-social-icon svg,
  .footer-inner-simple .footer-contact .footer-socials .footer-social-link-whatsapp .footer-social-icon svg {
    color: #263344 !important;
  }
}

/* NIKARI v94 readable dark hero image overlay */
@media (prefers-color-scheme: dark) {
  .home-page .home-hero.hero-slider {
    background:
      linear-gradient(180deg, rgba(38, 51, 68, .56) 0%, rgba(38, 51, 68, .48) 46%, rgba(38, 51, 68, .54) 100%),
      linear-gradient(90deg, rgba(38, 51, 68, .72) 0%, rgba(38, 51, 68, .54) 56%, rgba(38, 51, 68, .38) 100%),
      url("/site/images/nikari-hero-lobby.jpg") center / cover no-repeat !important;
  }

  .home-page .home-hero.hero-slider .hero-slider-bg {
    display: none !important;
  }
}

@media (prefers-color-scheme: dark) and (max-width: 720px) {
  .home-page .home-hero.hero-slider {
    background:
      linear-gradient(180deg, rgba(38, 51, 68, .62) 0%, rgba(38, 51, 68, .52) 44%, rgba(38, 51, 68, .58) 100%),
      linear-gradient(90deg, rgba(38, 51, 68, .70) 0%, rgba(38, 51, 68, .52) 100%),
      url("/site/images/nikari-hero-lobby.jpg") center / cover no-repeat !important;
  }
}

/* NIKARI v95 finer readable dark hero image overlay */
@media (prefers-color-scheme: dark) {
  .home-page .home-hero.hero-slider {
    background:
      linear-gradient(90deg, rgba(38, 51, 68, .58) 0%, rgba(38, 51, 68, .46) 58%, rgba(38, 51, 68, .34) 100%),
      url("/site/images/nikari-hero-lobby.jpg") center / cover no-repeat !important;
  }

  .home-page .home-hero.hero-slider .hero-slider-bg {
    display: none !important;
  }
}

@media (prefers-color-scheme: dark) and (max-width: 720px) {
  .home-page .home-hero.hero-slider {
    background:
      linear-gradient(180deg, rgba(38, 51, 68, .54) 0%, rgba(38, 51, 68, .48) 48%, rgba(38, 51, 68, .52) 100%),
      url("/site/images/nikari-hero-lobby.jpg") center / cover no-repeat !important;
  }
}

/* NIKARI v96 unified browser edges and footer surfaces */
@media (prefers-color-scheme: light) {
  html,
  body {
    background-color: #f8f3ed !important;
  }

  .site-footer {
    background: #f8f3ed !important;
  }
}

@media (prefers-color-scheme: dark) {
  html,
  body {
    background-color: #263344 !important;
  }

  .site-header,
  .home-page .site-header,
  .site-header.is-scrolled,
  .home-page .site-header.is-scrolled {
    background: #263344 !important;
    border-bottom-color: rgba(255, 250, 242, .14) !important;
  }

  .site-footer {
    background: #263344 !important;
    border-top-color: rgba(255, 250, 242, .14) !important;
  }

  @media (max-width: 1080px) {
    .nav-links,
    .home-page .nav-links {
      background: #263344 !important;
      border-color: rgba(255, 250, 242, .16) !important;
    }
  }
}

/* NIKARI v97 keep dark header black while status bar stays brand blue */
@media (prefers-color-scheme: dark) {
  .site-header,
  .home-page .site-header,
  .site-header.is-scrolled,
  .home-page .site-header.is-scrolled {
    background: rgba(12, 13, 15, .96) !important;
    border-bottom-color: rgba(255, 250, 242, .14) !important;
  }

  @media (max-width: 1080px) {
    .nav-links,
    .home-page .nav-links {
      background: #0c0d0f !important;
      border-color: rgba(255, 250, 242, .16) !important;
    }
  }
}

/* NIKARI v98 blue dark header only */
@media (prefers-color-scheme: dark) {
  .site-header,
  .home-page .site-header,
  .site-header.is-scrolled,
  .home-page .site-header.is-scrolled {
    background: #263344 !important;
    border-bottom-color: rgba(255, 250, 242, .14) !important;
  }

  @media (max-width: 1080px) {
    .nav-links,
    .home-page .nav-links {
      background: #263344 !important;
      border-color: rgba(255, 250, 242, .16) !important;
    }
  }
}

/* NIKARI v99: opt out of Samsung/Chromium automatic darkening. */
:root,
html,
body {
  color-scheme: only light;
  forced-color-adjust: none;
}

/* NIKARI v100: stronger opt out for Samsung/Chromium automatic darkening. */
:root,
html,
body {
  color-scheme: only light !important;
  forced-color-adjust: none !important;
}

/* NIKARI v107: section typography must stay quieter than the start-page title. */
:root {
  --nikari-section-title-size: clamp(24px, 2.45vw, 34px);
  --nikari-card-title-size: clamp(18px, 1.45vw, 21px);
}

h2,
.section-heading > h2,
.split-section h2,
.cta-section > h2,
.dark-cta > h2,
.feature-card > h2,
.price-panel .section-heading > h2 {
  font-size: var(--nikari-section-title-size) !important;
  line-height: 1.14 !important;
}

.card h3,
.process-step h3,
.timeline-item h3,
.price-card h3,
.data-room strong,
.pilot-node strong,
.price-path-step strong,
.price-factor strong {
  font-size: var(--nikari-card-title-size) !important;
  line-height: 1.2 !important;
}

.text-block {
  gap: 18px !important;
  font-size: 16px !important;
}

.section-heading > p,
.card p,
.process-step p,
.price-path-step p {
  font-size: 16px;
}

.demo-question {
  font-size: clamp(18px, 1.55vw, 22px) !important;
}

.demo-typing {
  font-size: 16px !important;
}

.home-page .price-start-section .price-teaser span {
  font-size: 16px !important;
}

@media (max-width: 720px) {
  :root {
    --nikari-section-title-size: clamp(23px, 7.1vw, 30px);
    --nikari-card-title-size: 19px;
  }

  h2,
  .section-heading > h2,
  .split-section h2,
  .cta-section > h2,
  .dark-cta > h2,
  .feature-card > h2 {
    line-height: 1.15 !important;
  }
}

/* NIKARI v108 pricing comparison */
.pricing-comparison-section {
  position: relative;
}

.pricing-comparison-heading {
  max-width: 880px;
}

.comparison-claim {
  margin-top: 16px;
  color: var(--color-brand-blue);
  font-weight: 700;
}

.pricing-comparison-module {
  margin-top: 26px;
}

.comparison-calculator {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(280px, .78fr) minmax(280px, .72fr);
  gap: 20px;
  align-items: stretch;
  padding: clamp(22px, 3vw, 30px);
  border: 1px solid rgba(38, 51, 68, .16);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .84), rgba(255, 250, 242, .72)),
    radial-gradient(circle at top right, rgba(218, 201, 166, .22), transparent 36%);
  box-shadow: var(--shadow-card);
}

.comparison-calculator h3,
.comparison-matrix-wrap h3 {
  margin: 0 0 10px;
  color: var(--color-text);
  font-size: var(--nikari-card-title-size);
  line-height: 1.2;
}

.comparison-controls {
  display: grid;
  gap: 14px;
  align-self: center;
}

.comparison-controls fieldset {
  min-width: 0;
  margin: 0;
  padding: 0;
  border: 0;
}

.comparison-controls legend {
  margin-bottom: 8px;
  color: var(--color-muted);
  font-size: 13px;
  font-weight: 700;
}

.comparison-options {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.comparison-options button {
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid rgba(38, 51, 68, .16);
  border-radius: 999px;
  background: rgba(255, 255, 255, .70);
  color: var(--color-brand-blue);
  cursor: pointer;
  font-size: 13px;
  font-weight: 700;
  transition: transform .16s ease, background .16s ease, border-color .16s ease, color .16s ease;
}

.comparison-options button:hover,
.comparison-options button.is-active {
  transform: translateY(-1px);
  border-color: rgba(38, 51, 68, .34);
  background: var(--color-brand-blue);
  color: #fffaf2;
}

.comparison-result {
  display: grid;
  align-content: center;
  gap: 10px;
  padding: 18px;
  border: 1px solid rgba(38, 51, 68, .14);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .70);
}

.comparison-result > span {
  color: var(--nikari-accent-gold-strong);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.comparison-result strong {
  color: var(--color-brand-blue);
  font-size: clamp(28px, 4vw, 44px) !important;
  font-weight: 300 !important;
  line-height: 1.05;
}

.comparison-result p {
  font-size: 13px;
  line-height: 1.45;
}

.comparison-range-track {
  position: relative;
  height: 9px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(38, 51, 68, .10);
}

.comparison-range-track i,
.comparison-range-track b {
  position: absolute;
  inset: 0 auto 0 0;
  border-radius: inherit;
  transition: width .38s ease;
}

.comparison-range-track i {
  width: var(--range-low, 1%);
  background: rgba(218, 201, 166, .85);
}

.comparison-range-track b {
  width: var(--range-high, 1.7%);
  background: linear-gradient(90deg, rgba(38, 51, 68, .18), rgba(38, 51, 68, .54));
  mix-blend-mode: multiply;
}

.pricing-comparison-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 18px;
}

.comparison-card {
  display: flex;
  min-height: 100%;
  flex-direction: column;
  gap: 16px;
  padding: 24px;
  border: 1px solid rgba(38, 51, 68, .15);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .70);
  box-shadow: 0 1px 0 rgba(255, 255, 255, .82) inset;
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.comparison-card:hover {
  transform: translateY(-3px);
  border-color: rgba(38, 51, 68, .28);
  box-shadow: 0 18px 46px rgba(38, 51, 68, .10);
  background: rgba(255, 255, 255, .84);
}

.comparison-card.is-featured {
  border-color: rgba(218, 201, 166, .44);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .86), rgba(255, 250, 242, .70)),
    rgba(255, 255, 255, .72);
}

.comparison-card-top {
  display: grid;
  gap: 8px;
}

.comparison-card-top h3 {
  margin: 0;
  color: var(--color-text);
  font-size: var(--nikari-card-title-size) !important;
  line-height: 1.2;
}

.comparison-card-top span {
  width: fit-content;
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border: 1px solid rgba(218, 201, 166, .34);
  border-radius: 999px;
  background: rgba(218, 201, 166, .18);
  color: var(--color-brand-blue);
  font-size: 12px;
  font-weight: 700;
}

.comparison-card > strong {
  margin-top: auto;
  color: var(--color-brand-blue);
  line-height: 1.3;
}

.comparison-matrix-wrap {
  margin-top: 20px;
  padding: 22px;
  border: 1px solid rgba(38, 51, 68, .14);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .62);
  box-shadow: var(--shadow-card);
}

.comparison-matrix-wrap .section-heading {
  margin-bottom: 16px;
}

.comparison-matrix {
  display: grid;
  overflow: hidden;
  border: 1px solid rgba(38, 51, 68, .12);
  border-radius: var(--radius);
}

.comparison-matrix [role="row"] {
  display: grid;
  grid-template-columns: minmax(170px, .82fr) repeat(3, minmax(150px, 1fr));
  border-top: 1px solid rgba(38, 51, 68, .10);
}

.comparison-matrix [role="row"]:first-child {
  border-top: 0;
}

.comparison-matrix [role="columnheader"],
.comparison-matrix [role="rowheader"],
.comparison-matrix [role="cell"] {
  min-width: 0;
  padding: 12px 14px;
  border-left: 1px solid rgba(38, 51, 68, .10);
}

.comparison-matrix [role="columnheader"]:first-child,
.comparison-matrix [role="rowheader"] {
  border-left: 0;
}

.comparison-matrix-head {
  background: rgba(38, 51, 68, .055);
  color: var(--color-brand-blue);
  font-weight: 700;
}

.comparison-matrix [role="rowheader"] {
  color: var(--color-text);
  font-weight: 700;
}

.comparison-matrix span {
  display: inline-flex;
  min-height: 26px;
  align-items: center;
  padding: 0 9px;
  border: 1px solid rgba(38, 51, 68, .12);
  border-radius: 999px;
  background: rgba(248, 243, 237, .72);
  color: var(--color-brand-blue);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.15;
}

.comparison-close {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  align-items: center;
  justify-content: space-between;
  margin-top: 22px;
  padding: 22px;
  border-radius: var(--radius);
  background: linear-gradient(135deg, #111923, #263344);
  color: #fffaf2;
}

.comparison-close p {
  color: rgba(255, 250, 242, .84);
  font-size: 18px;
}

@media (prefers-color-scheme: dark) {
  .comparison-calculator,
  .comparison-result,
  .comparison-card,
  .comparison-matrix-wrap,
  .comparison-matrix {
    border-color: rgba(255, 250, 242, .16) !important;
    background:
      linear-gradient(145deg, rgba(255, 250, 242, .075), rgba(255, 250, 242, .04)),
      rgba(12, 13, 15, .42) !important;
    box-shadow: 0 18px 48px rgba(0, 0, 0, .22);
  }

  .comparison-card.is-featured {
    border-color: rgba(218, 201, 166, .28) !important;
  }

  .comparison-card-top h3,
  .comparison-calculator h3,
  .comparison-matrix-wrap h3,
  .comparison-matrix [role="rowheader"],
  .comparison-card > strong,
  .comparison-result strong,
  .comparison-claim {
    color: #fffaf2 !important;
  }

  .comparison-card-top span,
  .comparison-matrix span {
    border-color: rgba(218, 201, 166, .28);
    background: rgba(218, 201, 166, .12);
    color: #dac9a6;
  }

  .comparison-matrix-head {
    background: rgba(255, 250, 242, .065);
    color: #fffaf2;
  }

  .comparison-matrix [role="row"],
  .comparison-matrix [role="columnheader"],
  .comparison-matrix [role="rowheader"],
  .comparison-matrix [role="cell"] {
    border-color: rgba(255, 250, 242, .11);
  }
}

@media (max-width: 1080px) {
  .comparison-calculator,
  .pricing-comparison-cards {
    grid-template-columns: 1fr;
  }

  .comparison-matrix {
    overflow-x: auto;
  }

  .comparison-matrix [role="row"] {
    min-width: 780px;
  }
}

@media (max-width: 720px) {
  .comparison-calculator {
    gap: 18px;
  }

  .comparison-options button {
    flex: 1 1 auto;
  }

  .comparison-result strong {
    font-size: 30px !important;
  }

  .comparison-card,
  .comparison-matrix-wrap,
  .comparison-close {
    padding: 18px;
  }

  .comparison-close {
    display: grid;
  }

  .comparison-close .button {
    width: 100%;
  }
}

/* NIKARI v109 mobile comparison matrix polish */
@media (max-width: 720px) {
  .comparison-matrix {
    overflow: visible;
  }

  .comparison-matrix-head {
    display: none !important;
  }

  .comparison-matrix [role="row"] {
    min-width: 0 !important;
    grid-template-columns: 1fr !important;
    border-top: 1px solid rgba(38, 51, 68, .12);
  }

  .comparison-matrix [role="row"]:first-child {
    border-top: 0;
  }

  .comparison-matrix [role="rowheader"] {
    padding: 14px 14px 8px;
    background: rgba(38, 51, 68, .045);
  }

  .comparison-matrix [role="cell"] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 9px 14px;
    border-left: 0;
    border-top: 1px solid rgba(38, 51, 68, .08);
  }

  .comparison-matrix [role="cell"]::before {
    color: var(--color-muted);
    font-size: 12px;
    font-weight: 700;
  }

  .comparison-matrix [role="cell"]:nth-child(2)::before {
    content: "Allgemeine Cloud-KI";
  }

  .comparison-matrix [role="cell"]:nth-child(3)::before {
    content: "Betreuter Datenraum";
  }

  .comparison-matrix [role="cell"]:nth-child(4)::before {
    content: "Eigene Instanz";
  }
}

@media (prefers-color-scheme: dark) and (max-width: 720px) {
  .comparison-matrix [role="rowheader"] {
    background: rgba(255, 250, 242, .055);
  }

  .comparison-matrix [role="cell"],
  .comparison-matrix [role="row"] {
    border-color: rgba(255, 250, 242, .10);
  }
}

/* NIKARI v110 data-room image section */
.data-room-photo-section {
  padding-top: 34px;
}

.data-room-photo-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, .78fr);
  gap: clamp(22px, 4vw, 54px);
  align-items: center;
}

.data-room-photo-panel {
  position: relative;
  min-height: 440px;
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(38, 51, 68, .16);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-card);
}

.data-room-photo-panel::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(38, 51, 68, .22), transparent 44%),
    linear-gradient(180deg, transparent 54%, rgba(17, 25, 35, .54));
}

.data-room-photo-panel img {
  width: 100%;
  height: 100%;
  min-height: 440px;
  display: block;
  object-fit: cover;
  object-position: center;
}

.data-room-photo-panel figcaption {
  position: absolute;
  z-index: 2;
  left: 24px;
  right: 24px;
  bottom: 22px;
  max-width: 520px;
  color: rgba(255, 250, 242, .90);
  font-size: 16px;
  line-height: 1.45;
  text-shadow: 0 12px 34px rgba(0, 0, 0, .44);
}

.data-room-photo-tags {
  position: absolute;
  z-index: 2;
  left: 18px;
  top: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.data-room-photo-tags span,
.data-room-photo-points span {
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border: 1px solid rgba(218, 201, 166, .30);
  border-radius: 999px;
  background: rgba(248, 243, 237, .16);
  color: #fffaf2;
  font-size: 12px;
  font-weight: 700;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.data-room-photo-copy {
  display: grid;
  gap: 16px;
}

.data-room-photo-copy h2 {
  margin-bottom: 0;
}

.data-room-photo-points {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
}

.data-room-photo-points span {
  border-color: rgba(38, 51, 68, .16);
  background: rgba(255, 255, 255, .70);
  color: var(--color-brand-blue);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

@media (prefers-color-scheme: dark) {
  .data-room-photo-panel {
    border-color: rgba(255, 250, 242, .15);
    background: rgba(12, 13, 15, .42);
    box-shadow: 0 18px 48px rgba(0, 0, 0, .24);
  }

  .data-room-photo-panel::after {
    background:
      linear-gradient(90deg, rgba(38, 51, 68, .48), transparent 48%),
      linear-gradient(180deg, transparent 48%, rgba(12, 13, 15, .66));
  }

  .data-room-photo-points span {
    border-color: rgba(255, 250, 242, .16);
    background: rgba(255, 250, 242, .07);
    color: #fffaf2;
  }
}

@media (max-width: 900px) {
  .data-room-photo-grid {
    grid-template-columns: 1fr;
  }

  .data-room-photo-panel,
  .data-room-photo-panel img {
    min-height: 360px;
  }
}

@media (max-width: 560px) {
  .data-room-photo-section {
    padding-top: 22px;
  }

  .data-room-photo-panel,
  .data-room-photo-panel img {
    min-height: 300px;
  }

  .data-room-photo-panel figcaption {
    left: 18px;
    right: 18px;
    bottom: 18px;
    font-size: 14px;
  }

  .data-room-photo-tags {
    left: 14px;
    top: 14px;
  }
}

/* NIKARI standalone photo sections */
.data-room-photo-section > .data-room-photo-panel {
  height: clamp(320px, 38vw, 470px);
  min-height: 0;
}

.data-room-photo-section > .data-room-photo-panel img {
  height: 100%;
  min-height: 0;
}

@media (max-width: 560px) {
  .data-room-photo-section > .data-room-photo-panel {
    height: clamp(260px, 70vw, 340px);
  }
}

/* NIKARI v111 data-room trust copy */
.data-room-hero .plain-explainer {
  max-width: 760px;
}

.room-question-grid .card,
.room-type-card,
.context-card {
  min-height: auto;
}

.rag-section .section-heading {
  max-width: 860px;
}

.rag-flow .process-step {
  min-height: 142px;
}

.rag-flow .process-step h3 {
  margin-bottom: 0;
}

.room-principle {
  margin-top: 22px;
  color: var(--color-brand-blue);
  font-weight: 700;
}

.room-question {
  width: fit-content;
  margin-top: 18px;
  padding: 12px 16px;
  border: 1px solid rgba(38, 51, 68, .16);
  border-radius: 999px;
  background: rgba(255, 255, 255, .72);
  color: var(--color-brand-blue);
  font-weight: 700;
}

.context-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.context-card > span {
  width: fit-content;
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border: 1px solid rgba(218, 201, 166, .34);
  border-radius: 999px;
  background: rgba(218, 201, 166, .18);
  color: var(--color-brand-blue);
  font-size: 12px;
  font-weight: 700;
}

.context-card strong {
  margin-top: auto;
  color: var(--color-brand-blue);
  line-height: 1.35;
}

.room-type-card {
  display: grid;
  gap: 14px;
}

.room-type-card .kicker {
  margin-bottom: -6px;
}

.room-type-card dl {
  display: grid;
  gap: 8px;
  margin: 0;
}

.room-type-card dt {
  color: var(--color-brand-blue);
  font-weight: 700;
}

.room-type-card dd {
  margin: 0 0 8px;
  color: var(--color-muted);
}

.room-risk-list {
  margin-top: 4px;
}

.room-plan-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 14px;
}

.room-plan-grid .price-path-step {
  min-height: 190px;
}

.operating-grid .feature-card > strong {
  color: var(--color-brand-blue);
}

.room-cta-prompts {
  justify-content: center;
  margin-top: 24px;
}

@media (prefers-color-scheme: dark) {
  .room-principle,
  .context-card strong,
  .room-type-card dt,
  .operating-grid .feature-card > strong,
  .room-question {
    color: #fffaf2;
  }

  .room-question,
  .context-card > span {
    border-color: rgba(218, 201, 166, .28);
    background: rgba(218, 201, 166, .12);
  }
}

@media (max-width: 1180px) {
  .room-plan-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .room-plan-grid,
  .operating-grid {
    grid-template-columns: 1fr;
  }

  .room-plan-grid .price-path-step,
  .rag-flow .process-step {
    min-height: auto;
  }
}

/* NIKARI v112 data-room plan readability */
.room-plan-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.room-plan-grid .price-path-step {
  min-height: 178px;
}

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

@media (max-width: 820px) {
  .room-plan-grid {
    grid-template-columns: 1fr !important;
  }
}

/* NIKARI v113 second data-room image */
.data-room-library-section {
  padding-top: 34px;
  padding-bottom: 34px;
}

.data-room-photo-grid-reverse {
  grid-template-columns: minmax(320px, .78fr) minmax(0, 1.12fr);
}

.data-room-library-panel img {
  object-position: center 45%;
}

.data-room-library-panel::after {
  background:
    linear-gradient(90deg, rgba(38, 51, 68, .30), transparent 48%),
    linear-gradient(180deg, transparent 50%, rgba(17, 25, 35, .58));
}

@media (max-width: 900px) {
  .data-room-photo-grid-reverse {
    grid-template-columns: 1fr;
  }

  .data-room-library-section .data-room-photo-copy {
    order: 2;
  }

  .data-room-library-section .data-room-photo-panel {
    order: 1;
  }
}

/* NIKARI v114 keep second data-room image aligned with first image height */
.data-room-library-panel {
  height: 440px;
  min-height: 440px;
}

.data-room-library-panel img {
  height: 100%;
  min-height: 0;
}

@media (max-width: 900px) {
  .data-room-library-panel {
    height: 360px;
    min-height: 360px;
  }
}

@media (max-width: 560px) {
  .data-room-library-panel {
    height: 300px;
    min-height: 300px;
  }
}

/* NIKARI v115 security data-sovereignty cockpit */
.security-hero .plain-explainer {
  max-width: 760px;
}

.data-sovereignty-cockpit .section-heading {
  max-width: 880px;
}

.data-sovereignty-cockpit .section-heading p:not(.kicker) {
  color: rgba(21, 21, 21, .78);
}

.data-sovereignty-cockpit .section-heading strong {
  color: var(--color-brand-blue);
}

.sovereignty-flow {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, .82fr) minmax(300px, 1.08fr) minmax(0, .82fr);
  gap: 16px;
  align-items: stretch;
  margin: 30px 0 22px;
}

.sovereignty-flow::before {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(38, 51, 68, .26), transparent);
  transform: translateY(-50%);
}

.sovereignty-node,
.sovereignty-gate {
  position: relative;
  z-index: 1;
  min-height: 226px;
  padding: 22px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .78);
  box-shadow: 0 1px 0 rgba(255, 255, 255, .82) inset;
}

.sovereignty-node {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.sovereignty-node span,
.gate-label {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  margin-bottom: 14px;
  padding: 0 10px;
  border: 1px solid rgba(218, 201, 166, .38);
  border-radius: 999px;
  background: rgba(218, 201, 166, .16);
  color: var(--color-brand-blue);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.sovereignty-node strong {
  display: block;
  margin-bottom: 8px;
  color: var(--color-brand-blue);
  font-size: 20px;
  line-height: 1.18;
}

.sovereignty-node p {
  max-width: 270px;
}

.sovereignty-gate {
  border-color: rgba(38, 51, 68, .24);
  background:
    linear-gradient(145deg, rgba(38, 51, 68, .95), rgba(38, 51, 68, .86)),
    var(--color-brand-blue);
  box-shadow: 0 22px 64px rgba(38, 51, 68, .16);
}

.sovereignty-gate .gate-label {
  border-color: rgba(255, 255, 255, .18);
  background: rgba(255, 255, 255, .08);
  color: #fffaf2;
}

.gate-checks {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.gate-check {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 44px;
  padding: 8px 12px 8px 34px;
  border: 1px solid rgba(255, 255, 255, .17);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .07);
  color: #fffaf2;
  font-weight: 700;
  line-height: 1.25;
}

.gate-check::before {
  content: "";
  position: absolute;
  left: 13px;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--color-gold);
  box-shadow: 0 0 0 5px rgba(218, 201, 166, .12);
}

.js .data-sovereignty-cockpit .gate-check {
  opacity: .34;
  transform: translateY(8px);
  transition: opacity .5s ease, transform .5s ease, border-color .5s ease, background .5s ease;
  transition-delay: calc(var(--i) * 120ms);
}

.js .data-sovereignty-cockpit.is-visible .gate-check {
  opacity: 1;
  transform: translateY(0);
  border-color: rgba(255, 255, 255, .27);
  background: rgba(255, 255, 255, .10);
}

.security-check-grid {
  margin-top: 18px;
}

.security-check-grid .card,
.security-no-false-grid .card {
  min-height: auto;
}

.security-claim {
  margin-top: 22px;
  color: var(--color-brand-blue);
  font-weight: 800;
}

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

.security-topic-card {
  min-height: auto;
  display: grid;
  gap: 14px;
}

.security-topic-card h2 {
  font-size: clamp(26px, 3vw, 36px);
}

.security-topic-card .check-list {
  margin-top: 0;
}

.security-topic-card > strong,
.security-operating-grid .feature-card > strong {
  color: var(--color-brand-blue);
}

.security-operating-grid .feature-card {
  min-height: auto;
}

.security-result-section {
  padding-top: 62px;
  padding-bottom: 62px;
}

@media (prefers-color-scheme: dark) {
  .data-sovereignty-cockpit .section-heading p:not(.kicker),
  .data-sovereignty-cockpit .section-heading strong,
  .security-claim,
  .sovereignty-node strong,
  .sovereignty-node span,
  .gate-label,
  .security-topic-card > strong,
  .security-operating-grid .feature-card > strong {
    color: #fffaf2;
  }

  .sovereignty-node,
  .security-topic-card {
    background: rgba(255, 255, 255, .055);
    border-color: rgba(255, 255, 255, .14);
  }

  .sovereignty-node span,
  .gate-label {
    border-color: rgba(218, 201, 166, .25);
    background: rgba(218, 201, 166, .10);
  }
}

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

  .sovereignty-flow::before {
    left: 50%;
    right: auto;
    top: 18px;
    bottom: 18px;
    width: 1px;
    height: auto;
    background: linear-gradient(180deg, transparent, rgba(38, 51, 68, .24), transparent);
  }

  .sovereignty-node,
  .sovereignty-gate {
    min-height: auto;
  }

  .security-topic-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .gate-checks {
    grid-template-columns: 1fr;
  }

  .sovereignty-node,
  .sovereignty-gate {
    padding: 18px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .js .data-sovereignty-cockpit .gate-check,
  .js .data-sovereignty-cockpit.is-visible .gate-check {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* NIKARI v116 data-room gate graphic */
.data-room-gate-graphic {
  padding-top: 44px;
}

.data-room-gate-graphic .section-heading {
  max-width: 860px;
}

.room-gate-warning {
  margin-top: 14px;
  color: var(--color-brand-blue);
  font-weight: 800;
}

.room-gate-tabs {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 4px 0 24px;
  padding: 6px;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: rgba(255, 255, 255, .58);
}

.room-gate-tab {
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: var(--color-brand-blue);
  font-weight: 800;
  cursor: pointer;
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease, color .18s ease;
}

.room-gate-tab:hover,
.room-gate-tab:focus-visible {
  border-color: rgba(38, 51, 68, .18);
  background: rgba(255, 255, 255, .72);
}

.room-gate-tab.is-active {
  border-color: rgba(38, 51, 68, .26);
  background: var(--color-brand-blue);
  color: #fff;
  box-shadow: 0 12px 28px rgba(38, 51, 68, .16);
}

.room-gate-flow {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, .78fr) minmax(340px, 1.12fr) minmax(0, 1fr);
  gap: 16px;
  align-items: stretch;
}

.room-gate-flow::before {
  content: "";
  position: absolute;
  z-index: 0;
  left: 7%;
  right: 7%;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(38, 51, 68, .24), transparent);
}

.room-gate-card {
  position: relative;
  z-index: 1;
  min-height: 348px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
}

.room-gate-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(145deg, rgba(218, 201, 166, .10), transparent 42%);
}

.room-gate-card > * {
  position: relative;
  z-index: 1;
}

.room-gate-label {
  width: fit-content;
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border: 1px solid rgba(218, 201, 166, .38);
  border-radius: 999px;
  background: rgba(218, 201, 166, .16);
  color: var(--color-brand-blue);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.room-gate-question h3 {
  margin-top: auto;
  font-size: clamp(28px, 3.2vw, 38px);
}

.room-gate-middle {
  border-color: rgba(38, 51, 68, .24);
  background:
    linear-gradient(145deg, rgba(38, 51, 68, .96), rgba(38, 51, 68, .88)),
    var(--color-brand-blue);
  color: #fffaf2;
  box-shadow: 0 22px 64px rgba(38, 51, 68, .16);
}

.room-gate-middle .room-gate-label,
.room-gate-middle p,
.room-gate-middle h3 {
  color: #fffaf2;
}

.room-gate-middle .room-gate-label {
  border-color: rgba(255, 255, 255, .18);
  background: rgba(255, 255, 255, .08);
}

.room-gate-lists {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: auto;
}

.room-gate-list {
  padding: 14px;
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .07);
}

.room-gate-list strong {
  display: block;
  margin-bottom: 10px;
  color: #fffaf2;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.room-gate-list ul,
.room-gate-answer-meta ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.room-gate-list li,
.room-gate-answer-meta li {
  position: relative;
  padding-left: 18px;
  line-height: 1.35;
}

.room-gate-list li::before,
.room-gate-answer-meta li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .55em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-gold);
}

.room-gate-blocked {
  opacity: .58;
}

.room-gate-blocked li::before {
  background: rgba(255, 255, 255, .50);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .22);
}

.room-gate-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.room-gate-badges span {
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border: 1px solid rgba(38, 51, 68, .16);
  border-radius: 999px;
  background: rgba(38, 51, 68, .06);
  color: var(--color-brand-blue);
  font-size: 12px;
  font-weight: 800;
}

.room-gate-answer-text {
  color: var(--color-brand-blue);
  font-weight: 700;
}

.room-gate-answer-meta {
  display: grid;
  gap: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--color-border);
}

.room-gate-answer-meta strong {
  color: var(--color-brand-blue);
}

.room-gate-rag-note {
  display: grid;
  grid-template-columns: 168px minmax(0, 1fr);
  gap: 16px;
  margin-top: 18px;
  padding: 16px 18px;
  border: 1px solid var(--color-brand-blue-line);
  border-left: 4px solid var(--color-brand-blue);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .72);
  box-shadow: 0 12px 36px rgba(38, 51, 68, .06);
}

.room-gate-rag-note strong {
  color: var(--color-brand-blue);
}

.room-gate-benefits {
  margin-top: 20px;
}

.js .room-gate-card.is-updating {
  opacity: .62;
  transform: translateY(4px);
}

.room-gate-card {
  transition: opacity .22s ease, transform .22s ease, border-color .22s ease;
}

@media (prefers-color-scheme: dark) {
  .room-gate-warning,
  .room-gate-label,
  .room-gate-rag-note strong,
  .room-gate-answer-text,
  .room-gate-answer-meta strong,
  .room-gate-badges span,
  .room-gate-tab {
    color: #fffaf2;
  }

  .room-gate-tabs,
  .room-gate-rag-note,
  .room-gate-card:not(.room-gate-middle) {
    background: rgba(255, 255, 255, .055);
    border-color: rgba(255, 255, 255, .14);
  }

  .room-gate-label,
  .room-gate-badges span {
    border-color: rgba(218, 201, 166, .25);
    background: rgba(218, 201, 166, .10);
  }
}

@media (max-width: 980px) {
  .room-gate-flow {
    grid-template-columns: 1fr;
  }

  .room-gate-flow::before {
    left: 50%;
    right: auto;
    top: 18px;
    bottom: 18px;
    width: 1px;
    height: auto;
    background: linear-gradient(180deg, transparent, rgba(38, 51, 68, .24), transparent);
  }

  .room-gate-card {
    min-height: auto;
  }

  .room-gate-question h3 {
    margin-top: 0;
  }
}

@media (max-width: 640px) {
  .data-room-gate-graphic {
    padding-top: 30px;
  }

  .room-gate-tabs {
    width: 100%;
    border-radius: var(--radius);
  }

  .room-gate-tab {
    flex: 1 1 100%;
  }

  .room-gate-lists,
  .room-gate-rag-note {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  .room-gate-tab,
  .room-gate-card,
  .js .room-gate-card.is-updating {
    transition: none;
    transform: none;
  }
}

/* NIKARI v117 data-room gate mobile order */
.room-gate-picker {
  display: grid;
  gap: 10px;
  margin-top: auto;
}

.room-gate-picker > strong {
  color: var(--color-brand-blue);
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.room-gate-picker .room-gate-tabs {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr;
  margin: 0;
  border-radius: var(--radius);
}

.room-gate-picker .room-gate-tab {
  width: 100%;
}

@media (prefers-color-scheme: dark) {
  .room-gate-picker > strong {
    color: #fffaf2;
  }
}

/* NIKARI v118 how-it-works answer chain */
.how-hero .plain-explainer {
  max-width: 760px;
}

.answer-chain-graphic {
  padding-top: 44px;
}

.answer-chain-graphic .section-heading {
  max-width: 900px;
}

.answer-chain-claim,
.answer-chain-final {
  margin-top: 14px;
  color: var(--color-brand-blue);
  font-weight: 800;
}

.answer-chain-tabs {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 4px 0 24px;
  padding: 6px;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: rgba(255, 255, 255, .58);
}

.answer-chain-tab {
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: var(--color-brand-blue);
  font-weight: 800;
  cursor: pointer;
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease, color .18s ease;
}

.answer-chain-tab:hover,
.answer-chain-tab:focus-visible {
  border-color: rgba(38, 51, 68, .18);
  background: rgba(255, 255, 255, .72);
}

.answer-chain-tab.is-active {
  border-color: rgba(38, 51, 68, .26);
  background: var(--color-brand-blue);
  color: #fff;
  box-shadow: 0 12px 28px rgba(38, 51, 68, .16);
}

.answer-chain-flow {
  position: relative;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
}

.answer-chain-flow::before {
  content: "";
  position: absolute;
  z-index: 0;
  left: 5%;
  right: 5%;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(38, 51, 68, .24), transparent);
}

.answer-chain-card {
  position: relative;
  z-index: 1;
  min-height: 292px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow: hidden;
}

.answer-chain-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(145deg, rgba(218, 201, 166, .10), transparent 42%);
}

.answer-chain-card > * {
  position: relative;
  z-index: 1;
}

.answer-chain-label {
  width: fit-content;
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border: 1px solid rgba(218, 201, 166, .38);
  border-radius: 999px;
  background: rgba(218, 201, 166, .16);
  color: var(--color-brand-blue);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.answer-chain-room,
.answer-chain-sources {
  border-color: rgba(38, 51, 68, .24);
  background:
    linear-gradient(145deg, rgba(38, 51, 68, .96), rgba(38, 51, 68, .88)),
    var(--color-brand-blue);
  color: #fffaf2;
  box-shadow: 0 22px 64px rgba(38, 51, 68, .14);
}

.answer-chain-room h3,
.answer-chain-room p,
.answer-chain-sources li,
.answer-chain-room .answer-chain-label,
.answer-chain-sources .answer-chain-label {
  color: #fffaf2;
}

.answer-chain-room .answer-chain-label,
.answer-chain-sources .answer-chain-label {
  border-color: rgba(255, 255, 255, .18);
  background: rgba(255, 255, 255, .08);
}

.answer-chain-docs ul,
.answer-chain-sources ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.answer-chain-docs li,
.answer-chain-sources li {
  position: relative;
  padding-left: 18px;
  line-height: 1.35;
}

.answer-chain-docs li::before,
.answer-chain-sources li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .55em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-gold);
}

.answer-chain-check h3,
.answer-chain-answer p {
  color: var(--color-brand-blue);
  font-weight: 800;
}

.answer-chain-rag-note {
  display: grid;
  grid-template-columns: 168px minmax(0, 1fr);
  gap: 16px;
  margin-top: 18px;
  padding: 16px 18px;
  border: 1px solid var(--color-brand-blue-line);
  border-left: 4px solid var(--color-brand-blue);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .72);
  box-shadow: 0 12px 36px rgba(38, 51, 68, .06);
}

.answer-chain-rag-note strong {
  color: var(--color-brand-blue);
}

.answer-chain-benefits,
.how-doc-badges {
  margin-top: 20px;
}

.js .answer-chain-card.is-updating {
  opacity: .62;
  transform: translateY(4px);
}

.answer-chain-card {
  transition: opacity .22s ease, transform .22s ease, border-color .22s ease;
}

.how-process-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.how-process-grid .price-path-step {
  min-height: 190px;
}

.how-question-grid .card,
.weak-foundation-grid .card,
.answer-type-grid .card {
  min-height: auto;
}

@media (prefers-color-scheme: dark) {
  .answer-chain-claim,
  .answer-chain-final,
  .answer-chain-label,
  .answer-chain-tab,
  .answer-chain-check h3,
  .answer-chain-answer p,
  .answer-chain-rag-note strong {
    color: #fffaf2;
  }

  .answer-chain-tabs,
  .answer-chain-rag-note,
  .answer-chain-card:not(.answer-chain-room):not(.answer-chain-sources) {
    background: rgba(255, 255, 255, .055);
    border-color: rgba(255, 255, 255, .14);
  }

  .answer-chain-label {
    border-color: rgba(218, 201, 166, .25);
    background: rgba(218, 201, 166, .10);
  }
}

@media (max-width: 1180px) {
  .answer-chain-flow,
  .how-process-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .answer-chain-card {
    min-height: 230px;
  }
}

@media (max-width: 760px) {
  .answer-chain-flow,
  .how-process-grid {
    grid-template-columns: 1fr;
  }

  .answer-chain-flow::before {
    left: 50%;
    right: auto;
    top: 18px;
    bottom: 18px;
    width: 1px;
    height: auto;
    background: linear-gradient(180deg, transparent, rgba(38, 51, 68, .24), transparent);
  }

  .answer-chain-tabs {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
    border-radius: var(--radius);
  }

  .answer-chain-tab {
    width: 100%;
  }

  .answer-chain-rag-note {
    grid-template-columns: 1fr;
  }

  .answer-chain-card,
  .how-process-grid .price-path-step {
    min-height: auto;
  }
}

@media (prefers-reduced-motion: reduce) {
  .answer-chain-tab,
  .answer-chain-card,
  .js .answer-chain-card.is-updating {
    transition: none;
    transform: none;
  }
}

/* NIKARI v119 answer chain desktop readability */
@media (min-width: 1181px) {
  .answer-chain-flow {
    grid-template-columns:
      minmax(138px, .92fr)
      minmax(160px, 1.06fr)
      minmax(150px, .98fr)
      minmax(150px, .98fr)
      minmax(170px, 1.08fr)
      minmax(230px, 1.46fr);
  }

  .answer-chain-card {
    padding: 22px;
  }
}

.answer-chain-answer p {
  font-size: 15.5px;
  line-height: 1.5;
  font-weight: 700;
}

.answer-chain-check h3 {
  font-size: 21px;
}

/* NIKARI v120 answer chain wider visual */
@media (min-width: 1181px) {
  .answer-chain-graphic {
    width: min(1360px, calc(100% - 32px));
  }

  .answer-chain-flow {
    grid-template-columns:
      minmax(170px, .92fr)
      minmax(190px, 1.05fr)
      minmax(180px, .98fr)
      minmax(180px, .98fr)
      minmax(195px, 1.06fr)
      minmax(260px, 1.40fr);
  }

  .answer-chain-question h3 {
    font-size: 22px;
  }
}

/* NIKARI v121 answer chain anchor offset */
.answer-chain-graphic {
  scroll-margin-top: 92px;
}


/* NIKARI v129 answer chain chat visual */
.answer-chat-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(300px, .55fr);
  gap: 18px;
  align-items: stretch;
}

.answer-chat-card {
  min-height: auto;
  overflow: hidden;
}

.answer-chat-main {
  padding: 0;
}

.answer-chat-topline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 18px 20px 0;
}

.answer-chat-status {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border: 1px solid rgba(218, 201, 166, .45);
  border-radius: 999px;
  background: rgba(218, 201, 166, .16);
  color: var(--color-brand-blue);
  font-size: 13px;
  font-weight: 800;
  white-space: nowrap;
}

.answer-chat-thread {
  display: grid;
  gap: 16px;
  padding: 20px;
}

.answer-chat-bubble {
  position: relative;
  display: grid;
  gap: 8px;
  max-width: 82%;
  padding: 16px 18px;
  border-radius: 18px;
  box-shadow: 0 14px 36px rgba(38, 51, 68, .08);
}

.answer-chat-bubble > span,
.answer-chat-context span,
.answer-chat-boundary span {
  color: rgba(38, 51, 68, .66);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.answer-chat-bubble p {
  margin: 0;
  font-size: clamp(18px, 2vw, 24px);
  line-height: 1.38;
  color: var(--color-brand-blue);
}

.answer-chat-user {
  justify-self: end;
  border: 1px solid rgba(38, 51, 68, .14);
  border-bottom-right-radius: 6px;
  background: rgba(255, 255, 255, .86);
}

.answer-chat-assistant {
  justify-self: start;
  max-width: min(760px, 90%);
  border: 1px solid rgba(38, 51, 68, .22);
  border-bottom-left-radius: 6px;
  background:
    linear-gradient(145deg, rgba(38, 51, 68, .97), rgba(38, 51, 68, .90)),
    var(--color-brand-blue);
}

.answer-chat-assistant > span,
.answer-chat-assistant p {
  color: #fffaf2;
}

.answer-chat-assistant p {
  min-height: 4.2em;
  font-size: clamp(17px, 1.55vw, 22px);
  font-weight: 750;
}

.answer-chat-assistant p.is-typing::after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 1.05em;
  margin-left: 3px;
  vertical-align: -.18em;
  border-radius: 999px;
  background: #fffaf2;
  animation: nikariTypeCursor .78s steps(1) infinite;
}

@keyframes nikariTypeCursor {
  50% { opacity: 0; }
}

.answer-chat-context {
  display: grid;
  grid-template-columns: minmax(180px, .5fr) minmax(0, 1fr);
  gap: 12px;
  align-items: stretch;
  max-width: 90%;
}

.answer-chat-context > div,
.answer-chat-boundary {
  display: grid;
  gap: 8px;
  padding: 14px 16px;
  border: 1px solid rgba(38, 51, 68, .12);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .64);
}

.answer-chat-context strong {
  color: var(--color-brand-blue);
  font-size: 18px;
}

.answer-chat-context ul,
.answer-chain-source-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.answer-chat-context li,
.answer-chain-source-list li {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  border: 1px solid rgba(38, 51, 68, .14);
  border-radius: 999px;
  background: rgba(255, 255, 255, .72);
  color: var(--color-brand-blue);
  font-size: 13px;
  font-weight: 800;
}

.answer-chat-proof {
  display: grid;
  gap: 14px;
  align-content: start;
  background:
    linear-gradient(145deg, rgba(218, 201, 166, .12), transparent 48%),
    rgba(255, 255, 255, .72);
}

.answer-chat-proof h3 {
  color: var(--color-brand-blue);
}

.answer-chat-boundary {
  margin-top: 4px;
}

.answer-chat-boundary p {
  margin: 0;
  color: var(--color-brand-blue);
  font-weight: 750;
}

.js .answer-chat-card.is-updating {
  opacity: .72;
  transform: translateY(3px);
}

.answer-chat-card {
  transition: opacity .22s ease, transform .22s ease, border-color .22s ease;
}

@media (prefers-color-scheme: dark) {
  .answer-chat-status,
  .answer-chat-context strong,
  .answer-chat-bubble p,
  .answer-chat-proof h3,
  .answer-chat-boundary p,
  .answer-chat-context li,
  .answer-chain-source-list li {
    color: #fffaf2;
  }

  .answer-chat-main,
  .answer-chat-proof,
  .answer-chat-user,
  .answer-chat-context > div,
  .answer-chat-boundary,
  .answer-chat-context li,
  .answer-chain-source-list li {
    background: rgba(255, 255, 255, .055);
    border-color: rgba(255, 255, 255, .14);
  }

  .answer-chat-bubble > span,
  .answer-chat-context span,
  .answer-chat-boundary span {
    color: rgba(255, 250, 242, .68);
  }
}

@media (max-width: 980px) {
  .answer-chat-shell {
    grid-template-columns: 1fr;
  }

  .answer-chat-context {
    max-width: none;
    grid-template-columns: 1fr;
  }

  .answer-chat-bubble,
  .answer-chat-assistant {
    max-width: 100%;
  }
}

@media (max-width: 760px) {
  .answer-chat-topline {
    align-items: flex-start;
    flex-direction: column;
  }

  .answer-chat-thread {
    padding: 16px;
  }

  .answer-chat-bubble {
    padding: 14px 15px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .answer-chat-assistant p.is-typing::after {
    animation: none;
  }

  .answer-chat-card,
  .js .answer-chat-card.is-updating {
    transition: none;
    transform: none;
  }
}



/* NIKARI v130 answer chain compact mobile tabs */
@media (max-width: 760px) {
  .answer-chain-tabs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    border-radius: 999px;
  }

  .answer-chain-tab {
    width: 100%;
    min-width: 0;
    padding-inline: 8px;
  }
}
/* NIKARI v122 pilot proof graphic */
.pilot-hero .plain-explainer {
  max-width: 760px;
}

.pilot-proof-graphic {
  width: min(1280px, calc(100% - 32px));
  padding-top: 44px;
  scroll-margin-top: 92px;
}

.pilot-proof-graphic .section-heading {
  max-width: 900px;
}

.pilot-proof-claim {
  margin-top: 14px;
  color: var(--color-brand-blue);
  font-weight: 800;
}

.pilot-proof-flow {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(340px, 1.16fr) minmax(0, .92fr);
  gap: 16px;
  align-items: stretch;
  margin-top: 26px;
}

.pilot-proof-flow::before {
  content: "";
  position: absolute;
  z-index: 0;
  left: 8%;
  right: 8%;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(38, 51, 68, .24), transparent);
}

.pilot-proof-card {
  position: relative;
  z-index: 1;
  min-height: 430px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
}

.pilot-proof-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(145deg, rgba(218, 201, 166, .10), transparent 42%);
}

.pilot-proof-card > * {
  position: relative;
  z-index: 1;
}

.pilot-proof-label {
  width: fit-content;
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border: 1px solid rgba(218, 201, 166, .38);
  border-radius: 999px;
  background: rgba(218, 201, 166, .16);
  color: var(--color-brand-blue);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.pilot-proof-input ul,
.pilot-proof-output ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.pilot-proof-input li,
.pilot-proof-output li {
  position: relative;
  padding-left: 18px;
  line-height: 1.35;
}

.pilot-proof-input li::before,
.pilot-proof-output li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .55em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-gold);
}

.pilot-proof-check {
  border-color: rgba(38, 51, 68, .24);
  background:
    linear-gradient(145deg, rgba(38, 51, 68, .96), rgba(38, 51, 68, .88)),
    var(--color-brand-blue);
  box-shadow: 0 22px 64px rgba(38, 51, 68, .16);
}

.pilot-proof-check h3,
.pilot-proof-check p,
.pilot-proof-check .pilot-proof-label {
  color: #fffaf2;
}

.pilot-proof-check .pilot-proof-label {
  border-color: rgba(255, 255, 255, .18);
  background: rgba(255, 255, 255, .08);
}

.pilot-proof-checks {
  display: grid;
  gap: 9px;
  margin-top: auto;
}

.pilot-check-item {
  display: grid;
  gap: 4px;
  width: 100%;
  min-height: 54px;
  padding: 10px 12px;
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .07);
  color: #fffaf2;
  text-align: left;
}

.pilot-check-item strong {
  color: #fffaf2;
  line-height: 1.2;
}

.pilot-check-item span {
  color: rgba(255, 250, 242, .76);
  font-size: 13px;
  line-height: 1.35;
}

.js .pilot-proof-graphic .pilot-check-item {
  opacity: .38;
  transform: translateY(8px);
  transition: opacity .5s ease, transform .5s ease, border-color .5s ease, background .5s ease;
  transition-delay: calc(var(--i) * 95ms);
}

.js .pilot-proof-graphic.is-visible .pilot-check-item {
  opacity: 1;
  transform: none;
  border-color: rgba(255, 255, 255, .27);
  background: rgba(255, 255, 255, .10);
}

.pilot-example-panel {
  margin-top: 18px;
  padding: 22px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .70);
  box-shadow: 0 1px 0 rgba(255, 255, 255, .82) inset;
}

.pilot-example-copy h3 {
  font-size: clamp(24px, 2.8vw, 34px);
}

.pilot-example-metrics {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0 20px;
}

.pilot-example-metrics span {
  min-height: 88px;
  display: grid;
  gap: 4px;
  align-content: center;
  padding: 14px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .62);
  color: var(--color-muted);
}

.pilot-example-metrics strong {
  color: var(--color-brand-blue);
  font-size: 26px;
  line-height: 1;
}

.pilot-proof-tabs {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 2px 0 16px;
  padding: 6px;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: rgba(255, 255, 255, .58);
}

.pilot-proof-tab {
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: var(--color-brand-blue);
  font-weight: 800;
  cursor: pointer;
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease, color .18s ease;
}

.pilot-proof-tab:hover,
.pilot-proof-tab:focus-visible {
  border-color: rgba(38, 51, 68, .18);
  background: rgba(255, 255, 255, .72);
}

.pilot-proof-tab.is-active {
  border-color: rgba(38, 51, 68, .26);
  background: var(--color-brand-blue);
  color: #fff;
  box-shadow: 0 12px 28px rgba(38, 51, 68, .16);
}

.pilot-example-result {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid rgba(38, 51, 68, .20);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, .74);
}

.pilot-example-result > span {
  width: fit-content;
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border: 1px solid rgba(218, 201, 166, .38);
  border-radius: 999px;
  background: rgba(218, 201, 166, .16);
  color: var(--color-brand-blue);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.pilot-example-result > p {
  color: var(--color-brand-blue);
  font-weight: 800;
}

.pilot-example-result-meta {
  display: grid;
  gap: 5px;
  padding-top: 10px;
  border-top: 1px solid var(--color-border);
}

.pilot-example-result-meta strong {
  color: var(--color-brand-blue);
}

.pilot-question-grid .card,
.pilot-evaluation-grid .card {
  min-height: auto;
}

.pilot-process-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.pilot-process-grid .price-path-step {
  min-height: 190px;
}

.pilot-price-hints {
  display: grid;
  gap: 10px;
}

.pilot-price-hints span {
  display: inline-flex;
  width: fit-content;
  min-height: 34px;
  align-items: center;
  padding: 0 12px;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: rgba(255, 255, 255, .64);
  color: var(--color-brand-blue);
  font-weight: 800;
}

.js .pilot-example-result.is-updating {
  opacity: .62;
  transform: translateY(4px);
}

.pilot-example-result {
  transition: opacity .22s ease, transform .22s ease;
}

@media (prefers-color-scheme: dark) {
  .pilot-proof-claim,
  .pilot-proof-label,
  .pilot-example-metrics strong,
  .pilot-proof-tab,
  .pilot-example-result > span,
  .pilot-example-result > p,
  .pilot-example-result-meta strong,
  .pilot-price-hints span {
    color: #fffaf2;
  }

  .pilot-proof-card:not(.pilot-proof-check),
  .pilot-example-panel,
  .pilot-example-result,
  .pilot-example-metrics span,
  .pilot-proof-tabs,
  .pilot-price-hints span {
    background: rgba(255, 255, 255, .055);
    border-color: rgba(255, 255, 255, .14);
  }

  .pilot-proof-label,
  .pilot-example-result > span {
    border-color: rgba(218, 201, 166, .25);
    background: rgba(218, 201, 166, .10);
  }
}

@media (max-width: 1100px) {
  .pilot-proof-flow,
  .pilot-process-grid {
    grid-template-columns: 1fr;
  }

  .pilot-proof-flow::before {
    left: 50%;
    right: auto;
    top: 18px;
    bottom: 18px;
    width: 1px;
    height: auto;
    background: linear-gradient(180deg, transparent, rgba(38, 51, 68, .24), transparent);
  }

  .pilot-proof-card,
  .pilot-process-grid .price-path-step {
    min-height: auto;
  }

  .pilot-example-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .pilot-proof-graphic {
    padding-top: 30px;
  }

  .pilot-example-panel {
    padding: 18px;
  }

  .pilot-example-metrics {
    grid-template-columns: 1fr;
  }

  .pilot-proof-tabs {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    border-radius: 999px;
  }

  .pilot-proof-tab {
    width: 100%;
    min-width: 0;
    padding-inline: 10px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .js .pilot-proof-graphic .pilot-check-item,
  .js .pilot-proof-graphic.is-visible .pilot-check-item,
  .pilot-proof-tab,
  .pilot-example-result,
  .js .pilot-example-result.is-updating {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* NIKARI v133: keep the home hero lead stable during title animation. */
.js .home-page .home-hero.reveal,
.js .home-page .home-hero.reveal.is-visible {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

.js .home-page .home-hero .lead {
  opacity: 1 !important;
  transform: none !important;
  animation: none !important;
}

/* NIKARI v136: security principle image panel */
.security-principle-section {
  align-items: stretch;
}

.security-principle-copy {
  display: grid;
  align-content: center;
  gap: 18px;
  min-height: 440px;
}

.security-principle-copy .security-claim {
  margin-top: 4px;
}

.security-principle-photo {
  min-height: 440px;
  overflow: hidden;
  padding: 0;
  background: var(--color-brand-blue);
}

.security-principle-photo img {
  width: 100%;
  height: 100%;
  min-height: 440px;
  display: block;
  object-fit: cover;
  object-position: center;
}

@media (max-width: 820px) {
  .security-principle-copy,
  .security-principle-photo,
  .security-principle-photo img {
    min-height: 0;
  }

  .security-principle-photo img {
    aspect-ratio: 4 / 3;
  }
}

/* NIKARI v138: quieter legal footer links */
.footer-powered span {
  opacity: .66 !important;
}

.footer-inner-simple .footer-contact {
  border-left: 1px solid color-mix(in srgb, var(--color-muted) 24%, transparent) !important;
}

.footer-inner-simple .footer-contact > span,
.footer-inner-simple .footer-contact a,
.footer-inner-simple .footer-contact a:link,
.footer-inner-simple .footer-contact a:visited {
  color: color-mix(in srgb, var(--color-muted) 70%, transparent) !important;
  font-size: 12px !important;
  font-weight: 300 !important;
  line-height: 1.25 !important;
  letter-spacing: 0 !important;
  opacity: .66 !important;
}

.footer-inner-simple .footer-contact a:hover,
.footer-inner-simple .footer-contact a:focus-visible {
  color: var(--color-text) !important;
  opacity: .86 !important;
}

@media (prefers-color-scheme: dark) {
  .footer-inner-simple .footer-contact {
    border-left-color: rgba(255, 250, 242, .18) !important;
  }

  .footer-inner-simple .footer-contact > span,
  .footer-inner-simple .footer-contact a,
  .footer-inner-simple .footer-contact a:link,
  .footer-inner-simple .footer-contact a:visited {
    color: rgba(255, 250, 242, .46) !important;
    opacity: 1 !important;
  }

  .footer-inner-simple .footer-contact a:hover,
  .footer-inner-simple .footer-contact a:focus-visible {
    color: rgba(255, 250, 242, .70) !important;
    opacity: 1 !important;
  }
}

@media (max-width: 820px) {
  .footer-inner-simple .footer-contact {
    border-left: 0 !important;
    border-top: 1px solid color-mix(in srgb, var(--color-muted) 20%, transparent) !important;
    padding: 16px 0 0 !important;
  }
}

/* NIKARI v141: restore home hero lead reveal without vertical jump. */
.js .home-page .home-hero .lead[data-lead-reveal].is-lead-animated {
  opacity: 1 !important;
  transform: none !important;
  animation: none !important;
}

.js .home-page .home-hero .lead[data-lead-reveal].is-lead-animated .lead-word {
  opacity: 0;
  filter: blur(7px);
  animation: leadWordRevealStable .72s ease forwards;
  animation-delay: calc(520ms + var(--i) * 42ms);
  will-change: opacity, filter;
}

@keyframes leadWordRevealStable {
  0% { opacity: 0; filter: blur(7px); }
  70% { opacity: .88; filter: blur(1px); }
  100% { opacity: 1; filter: blur(0); }
}

@media (prefers-reduced-motion: reduce) {
  .js .home-page .home-hero .lead[data-lead-reveal].is-lead-animated .lead-word {
    opacity: 1;
    filter: none;
    animation: none;
  }
}

/* NIKARI v143: quieter legal pages and polished impressum identity card. */
body[data-page="impressum"],
body[data-page="datenschutz"] {
  --nikari-legal-title-size: clamp(30px, 3.3vw, 44px);
  --nikari-legal-section-size: clamp(20px, 1.7vw, 26px);
  --nikari-legal-card-size: clamp(17px, 1.25vw, 20px);
}

body[data-page="impressum"] .page-hero,
body[data-page="datenschutz"] .page-hero {
  padding-bottom: 28px;
}

body[data-page="impressum"] h1,
body[data-page="datenschutz"] h1 {
  font-size: var(--nikari-legal-title-size) !important;
  line-height: 1.1 !important;
}

body[data-page="impressum"] .lead,
body[data-page="datenschutz"] .lead {
  max-width: 760px;
  font-size: clamp(16px, 1.35vw, 19px) !important;
  line-height: 1.55 !important;
}

body[data-page="impressum"] .section,
body[data-page="datenschutz"] .section {
  padding-top: clamp(34px, 5vw, 58px);
  padding-bottom: clamp(34px, 5vw, 58px);
}

body[data-page="impressum"] .feature-card > h2,
body[data-page="datenschutz"] .feature-card > h2 {
  font-size: var(--nikari-legal-section-size) !important;
  line-height: 1.18 !important;
}

body[data-page="impressum"] .card p,
body[data-page="datenschutz"] .card p,
body[data-page="impressum"] .legal-note,
body[data-page="datenschutz"] .legal-note {
  font-size: 15px !important;
  line-height: 1.58 !important;
}

.legal-identity-card {
  max-width: 980px;
  margin-inline: auto;
  padding: clamp(26px, 4vw, 42px) !important;
}

.legal-identity-head {
  display: grid;
  gap: 8px;
  max-width: 720px;
  margin-bottom: 24px;
}

.legal-identity-head h2 {
  margin: 0;
  font-size: var(--nikari-legal-title-size) !important;
  line-height: 1.08 !important;
}

.legal-identity-head p {
  margin: 0;
  color: var(--color-muted);
}

.legal-kicker,
.legal-fact-grid span,
.legal-contact-grid span,
.legal-address-note span {
  color: var(--nikari-accent-gold-strong);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
}

.legal-fact-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.legal-fact-grid div,
.legal-contact-grid a,
.legal-address-note {
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: rgba(255, 250, 242, .56);
}

.legal-fact-grid div {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
}

.legal-fact-grid strong {
  color: var(--color-text);
  font-size: var(--nikari-legal-card-size);
  line-height: 1.28;
}

.legal-contact-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.legal-contact-grid a {
  display: grid;
  gap: 6px;
  padding: 15px 16px;
  color: var(--color-text);
  text-decoration: none;
}

.legal-contact-grid a:hover,
.legal-contact-grid a:focus-visible {
  border-color: var(--color-brand-blue-line);
  background: rgba(255, 255, 255, .82);
}

.legal-contact-grid strong {
  overflow-wrap: anywhere;
  font-size: 15px;
  line-height: 1.25;
}

.legal-address-note {
  display: grid;
  gap: 6px;
  margin-top: 14px;
  padding: 15px 16px;
}

.legal-address-note p {
  margin: 0;
  color: var(--color-muted);
}

@media (max-width: 760px) {
  .legal-fact-grid,
  .legal-contact-grid {
    grid-template-columns: 1fr;
  }

  .legal-identity-card {
    padding: 22px !important;
  }
}



/* NIKARI v144: final legal compactness pass. */
body[data-page="impressum"],
body[data-page="datenschutz"] {
  --nikari-legal-title-size: clamp(28px, 3vw, 40px);
  --nikari-legal-section-size: clamp(19px, 1.45vw, 24px);
  --nikari-legal-card-size: clamp(16px, 1.05vw, 18px);
}

body[data-page="impressum"] .page-hero + .section,
body[data-page="datenschutz"] .page-hero + .section {
  padding-top: clamp(12px, 2.4vw, 28px);
}

body[data-page="impressum"] .feature-card > h2,
body[data-page="datenschutz"] .feature-card > h2 {
  font-size: var(--nikari-legal-section-size) !important;
}

.legal-identity-head h2 {
  max-width: 620px !important;
  font-size: clamp(24px, 2.45vw, 34px) !important;
  line-height: 1.12 !important;
}

.legal-identity-card {
  padding: clamp(22px, 3.2vw, 34px) !important;
}

/* NIKARI v146: scenario cards stay readable in blackscreen / dark mode. */
@media (prefers-color-scheme: dark) {
  .plain-explainer.scenario-insight-card {
    border-color: rgba(255, 250, 242, .22) !important;
    border-left-color: var(--nikari-accent-gold, #dac9a6) !important;
    background:
      linear-gradient(145deg, rgba(255, 250, 242, .09), rgba(255, 250, 242, .045)),
      rgba(12, 13, 15, .42) !important;
    color: #fffaf2 !important;
  }

  .plain-explainer.scenario-insight-card strong {
    color: #fffaf2 !important;
  }

  .plain-explainer.scenario-insight-card span {
    color: rgba(255, 250, 242, .84) !important;
    text-shadow: none !important;
  }

  .plain-explainer.scenario-insight-card svg {
    color: currentColor !important;
  }
}

/* NIKARI v148: restored static explanation cards stay readable in blackscreen / dark mode. */
@media (prefers-color-scheme: dark) {
  .plain-explainer {
    border-color: rgba(255, 250, 242, .22) !important;
    border-left-color: var(--nikari-accent-gold, #dac9a6) !important;
    background:
      linear-gradient(145deg, rgba(255, 250, 242, .09), rgba(255, 250, 242, .045)),
      rgba(12, 13, 15, .42) !important;
    color: #fffaf2 !important;
  }

  .plain-explainer strong {
    color: #fffaf2 !important;
  }

  .plain-explainer span {
    color: rgba(255, 250, 242, .84) !important;
    text-shadow: none !important;
  }
}

/* NIKARI v149: audience links stay clean without underline. */
.audience-card .card-body > a:not(.button) {
  border-bottom: 0 !important;
  text-decoration: none !important;
}

.audience-card .card-body > a:not(.button):hover,
.audience-card .card-body > a:not(.button):focus-visible {
  border-bottom: 0 !important;
  text-decoration: none !important;
}


/* NIKARI v153 pricing matrix */
.stage-matrix-wrap {
  padding: 0;
  overflow: visible;
}
.stage-matrix-scroll {
  overflow-x: auto;
  border-radius: var(--radius);
}
.stage-matrix {
  overflow: visible;
  border: 0;
  background: rgba(255, 255, 255, .62);
}
.stage-matrix .comparison-matrix-head {
  box-shadow: 0 1px 0 rgba(38, 51, 68, .08);
}
.stage-matrix [role="row"] {
  grid-template-columns: minmax(190px, .72fr) repeat(3, minmax(210px, 1fr));
  transition: background .18s ease, box-shadow .18s ease;
}
.stage-matrix [role="row"]:not(.comparison-matrix-head):hover {
  background: rgba(255, 255, 255, .72);
  box-shadow: 0 1px 0 rgba(38, 51, 68, .08) inset;
}
.stage-matrix [role="columnheader"] strong {
  display: block;
  color: var(--color-text);
  font-size: var(--nikari-card-title-size);
  line-height: 1.2;
}
.stage-matrix [role="columnheader"] small {
  display: block;
  margin-top: 6px;
  color: rgba(21, 21, 21, .70);
  font-size: 12px;
  line-height: 1.3;
}
.stage-matrix .is-featured-cell {
  background: linear-gradient(180deg, rgba(218, 201, 166, .13), rgba(255, 255, 255, .28));
}
.stage-mobile-cards {
  display: none;
}
.stage-mobile-list {
  display: grid;
  gap: 0;
  margin: 0;
}
.stage-mobile-list dt,
.stage-mobile-list dd {
  margin: 0;
  padding: 10px 0;
  border-top: 1px solid rgba(38, 51, 68, .10);
}
.stage-mobile-list dt {
  color: var(--color-brand-blue);
  font-weight: 700;
}
.stage-mobile-list dd {
  color: rgba(21, 21, 21, .78);
}
.stage-notes {
  margin-top: 0;
}
.stage-notes .check-list {
  margin: 0;
}
.stage-module-intro {
  max-width: 780px;
  margin-top: -8px;
  color: rgba(21, 21, 21, .78);
}
.module-tile-grid {
  margin-top: 22px;
}
.module-tile {
  min-height: 96px;
  display: flex;
  align-items: center;
}
.module-tile strong {
  margin: 0;
}
@media (max-width: 1080px) {
  .stage-matrix [role="row"] {
    min-width: 920px;
  }
}
@media (max-width: 720px) {
  .stage-matrix-scroll {
    display: none;
  }
  .stage-mobile-cards {
    display: grid;
  }
  .stage-mobile-list dt,
  .stage-mobile-list dd {
    padding: 8px 0;
  }
  .module-tile {
    min-height: 82px;
  }
}


/* NIKARI v155 pricing matrix enhancement */
.stage-evidence-grid,
.stage-module-groups {
  margin-top: 20px;
}
.stage-evidence-card {
  min-height: 96px;
  display: flex;
  align-items: center;
}
.stage-evidence-card strong,
.stage-module-group strong {
  margin-bottom: 0;
}
.stage-module-group {
  min-height: 210px;
}
.stage-module-group .check-list {
  margin-top: 14px;
}
.stage-care-limits .check-list {
  margin: 0;
}
.stage-payment-grid .price-card {
  min-height: 170px;
}
@media (max-width: 720px) {
  .stage-module-group,
  .stage-payment-grid .price-card {
    min-height: auto;
  }
  .stage-evidence-card {
    min-height: 78px;
  }
}

/* NIKARI v156 pricing color alignment */
body[data-page="preise"] .stage-matrix-wrap {
  border-color: var(--color-border);
  background: rgba(255, 255, 255, .68);
  box-shadow: 0 1px 0 rgba(255, 255, 255, .82) inset;
}

body[data-page="preise"] .stage-matrix {
  border-color: var(--color-border);
  background: rgba(255, 255, 255, .68);
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head {
  background: var(--color-brand-blue-soft);
  color: var(--color-brand-blue);
}

body[data-page="preise"] .stage-matrix .is-featured-cell {
  background: rgba(38, 51, 68, .045);
  box-shadow: inset 3px 0 0 rgba(38, 51, 68, .20);
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head .is-featured-cell {
  background: rgba(38, 51, 68, .075);
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head span,
body[data-page="preise"] .comparison-card.is-featured .comparison-card-top span {
  border-color: var(--color-brand-blue);
  background: var(--color-brand-blue);
  color: #fffaf2;
}

body[data-page="preise"] .comparison-card.is-featured {
  border-color: rgba(38, 51, 68, .24);
  background: rgba(255, 255, 255, .74);
  box-shadow: 0 1px 0 rgba(255, 255, 255, .82) inset;
}

body[data-page="preise"] .stage-evidence-card,
body[data-page="preise"] .stage-module-group,
body[data-page="preise"] #care .price-card,
body[data-page="preise"] #zahlung .price-card {
  border-color: var(--color-border);
  background: rgba(255, 255, 255, .68);
  box-shadow: 0 1px 0 rgba(255, 255, 255, .82) inset;
}

body[data-page="preise"] .stage-evidence-card:hover,
body[data-page="preise"] .stage-module-group:hover,
body[data-page="preise"] #care .price-card:hover,
body[data-page="preise"] #zahlung .price-card:hover {
  border-color: rgba(38, 51, 68, .24);
  background: rgba(255, 255, 255, .82);
  box-shadow: 0 18px 46px rgba(38, 51, 68, .10);
}


/* NIKARI v157 pricing stage highlight refinement */
body[data-page="preise"] .stage-matrix .is-featured-cell {
  background: rgba(255, 255, 255, .72);
  box-shadow: inset 3px 0 0 var(--color-brand-blue-line);
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head .is-featured-cell {
  background: rgba(255, 255, 255, .74);
}

/* NIKARI v158 pricing visual correction */
html:has(body[data-page="preise"]),
body[data-page="preise"] {
  overflow-x: hidden;
  background:
    radial-gradient(circle at 16% 14%, rgba(218, 201, 166, .18), transparent 30%),
    linear-gradient(145deg, #f8f3ed 0%, #fffdf9 52%, #f8f3ed 100%) !important;
  color: var(--color-text) !important;
}

body[data-page="preise"] .site-header {
  background: rgba(248, 243, 237, .90) !important;
  border-bottom-color: rgba(23, 22, 18, .08) !important;
  color: var(--color-text) !important;
}

body[data-page="preise"] .brand span,
body[data-page="preise"] .nav-links,
body[data-page="preise"] .nav-links a,
body[data-page="preise"] h1,
body[data-page="preise"] h2,
body[data-page="preise"] h3,
body[data-page="preise"] p,
body[data-page="preise"] .lead,
body[data-page="preise"] .section-heading > p,
body[data-page="preise"] .check-list,
body[data-page="preise"] .price-for {
  color: inherit;
}

body[data-page="preise"] .lead,
body[data-page="preise"] .section-heading > p,
body[data-page="preise"] .price-for,
body[data-page="preise"] .check-list {
  color: rgba(21, 21, 21, .76) !important;
}

body[data-page="preise"] .kicker,
body[data-page="preise"] .eyebrow,
body[data-page="preise"] .price-badge {
  color: var(--nikari-accent-gold-strong) !important;
}

body[data-page="preise"] .section {
  width: min(var(--max), calc(100% - 32px));
  overflow: visible;
}

body[data-page="preise"] .stage-matrix-wrap {
  max-width: 100%;
  overflow: hidden;
  padding: 0 !important;
  border-color: var(--color-border) !important;
  background: rgba(255, 255, 255, .68) !important;
  box-shadow: var(--shadow-card) !important;
}

body[data-page="preise"] .stage-matrix-scroll {
  max-width: 100%;
  overflow-x: auto;
  overscroll-behavior-x: contain;
}

body[data-page="preise"] .stage-matrix {
  width: 100%;
  min-width: 0;
  border-color: var(--color-border) !important;
  background: rgba(255, 255, 255, .72) !important;
  color: var(--color-text) !important;
}

body[data-page="preise"] .stage-matrix [role="row"] {
  grid-template-columns: minmax(150px, .62fr) repeat(3, minmax(0, 1fr));
}

body[data-page="preise"] .stage-matrix [role="columnheader"],
body[data-page="preise"] .stage-matrix [role="rowheader"],
body[data-page="preise"] .stage-matrix [role="cell"] {
  padding: 16px 18px;
  border-color: rgba(38, 51, 68, .10) !important;
  color: var(--color-text) !important;
  font-size: 15.5px;
  line-height: 1.42;
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head {
  background: rgba(38, 51, 68, .045) !important;
  color: var(--color-brand-blue) !important;
}

body[data-page="preise"] .stage-matrix [role="columnheader"] strong,
body[data-page="preise"] .stage-matrix [role="rowheader"] {
  color: var(--color-brand-blue) !important;
  font-weight: 700 !important;
}

body[data-page="preise"] .stage-matrix [role="columnheader"] small {
  color: rgba(21, 21, 21, .62) !important;
}

body[data-page="preise"] .stage-matrix .is-featured-cell {
  background: rgba(38, 51, 68, .035) !important;
  box-shadow: inset 3px 0 0 rgba(38, 51, 68, .18) !important;
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head .is-featured-cell {
  background: rgba(38, 51, 68, .06) !important;
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head span,
body[data-page="preise"] .comparison-card.is-featured .comparison-card-top span {
  border-color: var(--color-brand-blue) !important;
  background: var(--color-brand-blue) !important;
  color: #fffaf2 !important;
}

body[data-page="preise"] .comparison-card,
body[data-page="preise"] .stage-evidence-card,
body[data-page="preise"] .stage-module-group,
body[data-page="preise"] #care .price-card,
body[data-page="preise"] #zahlung .price-card,
body[data-page="preise"] .plain-explainer {
  border-color: var(--color-border) !important;
  background: rgba(255, 255, 255, .68) !important;
  color: var(--color-text) !important;
  box-shadow: 0 1px 0 rgba(255, 255, 255, .82) inset !important;
}

body[data-page="preise"] .plain-explainer {
  border-left-color: var(--color-brand-blue) !important;
}

body[data-page="preise"] .comparison-card.is-featured {
  border-color: rgba(38, 51, 68, .24) !important;
  background: rgba(255, 255, 255, .76) !important;
}

@media (min-width: 1081px) {
  body[data-page="preise"] .stage-matrix [role="row"] {
    min-width: 0 !important;
  }
}

@media (max-width: 1080px) {
  body[data-page="preise"] .stage-matrix [role="row"] {
    min-width: 900px !important;
  }
}

@media (max-width: 720px) {
  body[data-page="preise"] .section {
    width: min(var(--max), calc(100% - 24px));
  }
}

@media (max-width: 560px) {
  body[data-page="preise"] .page-hero h1 {
    max-width: 100%;
    font-size: clamp(31px, 8.7vw, 38px) !important;
    line-height: 1.12 !important;
  }

  body[data-page="preise"] .page-hero .lead {
    max-width: 100%;
  }
}


/* NIKARI v159 pricing dark-mode text hardening */
body[data-page="preise"] .price-card h3,
body[data-page="preise"] .price-card strong,
body[data-page="preise"] .price-factor strong,
body[data-page="preise"] .comparison-card-top h3,
body[data-page="preise"] .plain-explainer strong {
  color: var(--color-brand-blue) !important;
}

body[data-page="preise"] .price-card p,
body[data-page="preise"] .price-factor p,
body[data-page="preise"] .price-factor li,
body[data-page="preise"] .comparison-card li,
body[data-page="preise"] .comparison-card dd,
body[data-page="preise"] .plain-explainer span,
body[data-page="preise"] .stage-mobile-list dd {
  color: rgba(21, 21, 21, .76) !important;
}

body[data-page="preise"] .stage-mobile-list dt,
body[data-page="preise"] .comparison-card > strong {
  color: var(--color-brand-blue) !important;
}

body[data-page="preise"] .stage-matrix-scroll {
  overflow-y: hidden;
}

/* NIKARI v160 pricing explicit light/dark surfaces */
body[data-page="preise"] {
  --preise-text: #151515;
  --preise-muted: rgba(21, 21, 21, .76);
  --preise-title: #263344;
  --preise-surface: rgba(255, 255, 255, .70);
  --preise-surface-strong: rgba(255, 255, 255, .86);
  --preise-line: rgba(38, 51, 68, .12);
  --preise-line-strong: rgba(38, 51, 68, .22);
  --preise-soft: rgba(38, 51, 68, .045);
  --preise-feature: rgba(38, 51, 68, .055);
  background:
    radial-gradient(circle at 16% 14%, rgba(218, 201, 166, .18), transparent 30%),
    linear-gradient(145deg, #f8f3ed 0%, #fffdf9 52%, #f8f3ed 100%) !important;
  color: var(--preise-text) !important;
}

body[data-page="preise"] .site-header {
  background: rgba(248, 243, 237, .90) !important;
  border-bottom-color: rgba(23, 22, 18, .08) !important;
  color: var(--preise-text) !important;
}

body[data-page="preise"] .brand span,
body[data-page="preise"] .nav-links,
body[data-page="preise"] .nav-links a,
body[data-page="preise"] h1,
body[data-page="preise"] h2,
body[data-page="preise"] h3,
body[data-page="preise"] .stage-matrix [role="columnheader"] strong,
body[data-page="preise"] .stage-matrix [role="rowheader"],
body[data-page="preise"] .price-card h3,
body[data-page="preise"] .price-card strong,
body[data-page="preise"] .price-factor strong,
body[data-page="preise"] .plain-explainer strong {
  color: var(--preise-title) !important;
}

body[data-page="preise"] p,
body[data-page="preise"] .lead,
body[data-page="preise"] .section-heading > p,
body[data-page="preise"] .price-for,
body[data-page="preise"] .check-list,
body[data-page="preise"] .stage-matrix [role="cell"],
body[data-page="preise"] .stage-matrix [role="columnheader"] small,
body[data-page="preise"] .stage-mobile-list dd,
body[data-page="preise"] .plain-explainer span {
  color: var(--preise-muted) !important;
}

body[data-page="preise"] .stage-matrix-wrap,
body[data-page="preise"] .stage-matrix,
body[data-page="preise"] .comparison-card,
body[data-page="preise"] .stage-evidence-card,
body[data-page="preise"] .stage-module-group,
body[data-page="preise"] #care .price-card,
body[data-page="preise"] #zahlung .price-card,
body[data-page="preise"] .plain-explainer {
  border-color: var(--preise-line) !important;
  background: var(--preise-surface) !important;
  color: var(--preise-text) !important;
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head {
  background: var(--preise-soft) !important;
  color: var(--preise-title) !important;
}

body[data-page="preise"] .stage-matrix [role="columnheader"],
body[data-page="preise"] .stage-matrix [role="rowheader"],
body[data-page="preise"] .stage-matrix [role="cell"],
body[data-page="preise"] .stage-mobile-list dt,
body[data-page="preise"] .stage-mobile-list dd,
body[data-page="preise"] .price-card h3 {
  border-color: var(--preise-line) !important;
}

body[data-page="preise"] .stage-matrix .is-featured-cell,
body[data-page="preise"] .stage-matrix .comparison-matrix-head .is-featured-cell,
body[data-page="preise"] .comparison-card.is-featured {
  background: var(--preise-feature) !important;
  border-color: var(--preise-line-strong) !important;
  box-shadow: inset 3px 0 0 var(--preise-line-strong) !important;
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head span,
body[data-page="preise"] .comparison-card.is-featured .comparison-card-top span {
  border-color: #263344 !important;
  background: #263344 !important;
  color: #fffaf2 !important;
}

@media (prefers-color-scheme: dark) {
  body[data-page="preise"] {
    --preise-text: #fffaf2;
    --preise-muted: rgba(255, 250, 242, .74);
    --preise-title: #fffaf2;
    --preise-surface: rgba(255, 250, 242, .065);
    --preise-surface-strong: rgba(255, 250, 242, .095);
    --preise-line: rgba(255, 250, 242, .14);
    --preise-line-strong: rgba(218, 201, 166, .34);
    --preise-soft: rgba(255, 250, 242, .075);
    --preise-feature: rgba(218, 201, 166, .105);
    background:
      radial-gradient(circle at 18% 12%, rgba(218, 201, 166, .13), transparent 30%),
      linear-gradient(145deg, #111923 0%, #172231 52%, #101722 100%) !important;
    color: var(--preise-text) !important;
  }

  body[data-page="preise"] .site-header {
    background: rgba(17, 25, 35, .90) !important;
    border-bottom-color: rgba(255, 250, 242, .12) !important;
    color: var(--preise-text) !important;
  }

  body[data-page="preise"] .button.secondary,
  body[data-page="preise"] .nav-cta {
    border-color: rgba(255, 250, 242, .22) !important;
    background: rgba(255, 250, 242, .06) !important;
    color: var(--preise-text) !important;
  }

  body[data-page="preise"] .button.primary {
    background: #fffaf2 !important;
    border-color: #fffaf2 !important;
    color: #263344 !important;
    box-shadow: 0 14px 34px rgba(0, 0, 0, .22) !important;
  }

  body[data-page="preise"] .kicker,
  body[data-page="preise"] .eyebrow,
  body[data-page="preise"] .price-badge {
    color: #dac9a6 !important;
  }

  body[data-page="preise"] .stage-matrix-wrap,
  body[data-page="preise"] .stage-matrix,
  body[data-page="preise"] .comparison-card,
  body[data-page="preise"] .stage-evidence-card,
  body[data-page="preise"] .stage-module-group,
  body[data-page="preise"] #care .price-card,
  body[data-page="preise"] #zahlung .price-card,
  body[data-page="preise"] .plain-explainer {
    border-color: var(--preise-line) !important;
    background: var(--preise-surface) !important;
    color: var(--preise-text) !important;
    box-shadow: 0 18px 48px rgba(0, 0, 0, .18) !important;
  }

  body[data-page="preise"] .stage-matrix .comparison-matrix-head {
    background: rgba(255, 250, 242, .08) !important;
  }

  body[data-page="preise"] .stage-matrix [role="columnheader"],
  body[data-page="preise"] .stage-matrix [role="rowheader"],
  body[data-page="preise"] .stage-matrix [role="cell"] {
    border-color: var(--preise-line) !important;
  }

  body[data-page="preise"] .stage-matrix .is-featured-cell,
  body[data-page="preise"] .stage-matrix .comparison-matrix-head .is-featured-cell,
  body[data-page="preise"] .comparison-card.is-featured {
    background: var(--preise-feature) !important;
    border-color: var(--preise-line-strong) !important;
    box-shadow: inset 3px 0 0 var(--preise-line-strong) !important;
  }

  body[data-page="preise"] .stage-matrix .comparison-matrix-head span,
  body[data-page="preise"] .comparison-card.is-featured .comparison-card-top span {
    border-color: rgba(218, 201, 166, .42) !important;
    background: rgba(218, 201, 166, .16) !important;
    color: #dac9a6 !important;
  }
}


/* NIKARI v161 pricing dark text cleanup */
@media (prefers-color-scheme: dark) {
  body[data-page="preise"] .price-card p,
  body[data-page="preise"] .price-card .price-for,
  body[data-page="preise"] .price-factor p,
  body[data-page="preise"] .price-factor li,
  body[data-page="preise"] .check-list,
  body[data-page="preise"] .check-list li,
  body[data-page="preise"] .plain-explainer span,
  body[data-page="preise"] .stage-mobile-list dd {
    color: rgba(255, 250, 242, .74) !important;
  }

  body[data-page="preise"] .price-badge,
  body[data-page="preise"] .kicker,
  body[data-page="preise"] .eyebrow {
    color: #dac9a6 !important;
  }

  body[data-page="preise"] .price-card h3,
  body[data-page="preise"] .price-card strong,
  body[data-page="preise"] .price-factor strong,
  body[data-page="preise"] .plain-explainer strong,
  body[data-page="preise"] .stage-mobile-list dt {
    color: #fffaf2 !important;
  }
}

/* NIKARI v162 pricing matrix contrast cleanup */
body[data-page="preise"] .stage-matrix [role="columnheader"],
body[data-page="preise"] .stage-matrix [role="rowheader"] {
  color: #263344 !important;
  font-weight: 700 !important;
  opacity: 1 !important;
}

body[data-page="preise"] .stage-matrix [role="cell"] {
  color: #354253 !important;
  font-weight: 400 !important;
  opacity: 1 !important;
}

body[data-page="preise"] .stage-matrix small,
body[data-page="preise"] .stage-mobile-list dd {
  color: #354253 !important;
  font-weight: 600 !important;
  opacity: 1 !important;
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head small {
  color: #354253 !important;
}

body[data-page="preise"] .stage-matrix .is-featured-cell {
  color: #3f4b58 !important;
}

body[data-page="preise"] .section-heading p {
  color: #44505e !important;
  font-weight: 400 !important;
}

@media (prefers-color-scheme: dark) {
  body[data-page="preise"] .stage-matrix [role="columnheader"],
  body[data-page="preise"] .stage-matrix [role="rowheader"] {
    color: #fffaf2 !important;
  }

  body[data-page="preise"] .stage-matrix [role="cell"],
  body[data-page="preise"] .stage-matrix small,
  body[data-page="preise"] .stage-mobile-list dd {
    color: rgba(255, 250, 242, .78) !important;
  }

  body[data-page="preise"] .stage-matrix .comparison-matrix-head small,
  body[data-page="preise"] .stage-matrix .is-featured-cell {
    color: rgba(255, 250, 242, .86) !important;
  }

  body[data-page="preise"] .section-heading p {
    color: rgba(255, 250, 242, .76) !important;
  }
}

/* NIKARI v165 stage price and recommended badge placement */
body[data-page="preise"] .stage-matrix .comparison-matrix-head .is-featured-cell {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px 12px;
  align-content: start;
  align-items: start;
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head .is-featured-cell strong {
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head .is-featured-cell span {
  grid-column: 2;
  grid-row: 1;
  justify-self: end;
  white-space: nowrap;
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head .is-featured-cell small {
  grid-column: 1 / -1;
}

body[data-page="preise"] .comparison-card.is-featured .comparison-card-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px 12px;
  align-items: start;
}

body[data-page="preise"] .comparison-card.is-featured .comparison-card-top h3 {
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
}

body[data-page="preise"] .comparison-card.is-featured .comparison-card-top span {
  grid-column: 2;
  grid-row: 1;
  justify-self: end;
  white-space: nowrap;
}

/* NIKARI v163 simple/technical handover flip cards */
body[data-page="preise"] .stage-flip-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 28px;
}

body[data-page="preise"] .stage-flip-card {
  min-height: 230px;
  perspective: 1200px;
}

body[data-page="preise"] .stage-flip-toggle {
  appearance: none;
  background: transparent;
  border: 0;
  cursor: pointer;
  display: block;
  font: inherit;
  height: 100%;
  min-height: 230px;
  padding: 0;
  position: relative;
  text-align: left;
  width: 100%;
}

body[data-page="preise"] .stage-flip-face {
  backface-visibility: hidden;
  background: rgba(255, 255, 255, .9);
  border: 1px solid rgba(38, 51, 68, .14);
  border-radius: 18px;
  box-shadow: 0 16px 42px rgba(38, 51, 68, .08);
  color: #263344;
  display: flex;
  flex-direction: column;
  gap: 12px;
  inset: 0;
  justify-content: space-between;
  min-height: 230px;
  padding: 24px;
  position: absolute;
  transition: transform .42s ease, border-color .2s ease, box-shadow .2s ease;
  transform-style: preserve-3d;
}

body[data-page="preise"] .stage-flip-back {
  background: #263344;
  border-color: rgba(217, 182, 111, .34);
  color: #fffaf2;
  transform: rotateY(-180deg);
}

body[data-page="preise"] .stage-flip-toggle[aria-expanded="true"] .stage-flip-front {
  transform: rotateY(180deg);
}

body[data-page="preise"] .stage-flip-toggle[aria-expanded="true"] .stage-flip-back {
  transform: rotateY(0deg);
}

body[data-page="preise"] .stage-flip-toggle:hover .stage-flip-face,
body[data-page="preise"] .stage-flip-toggle:focus-visible .stage-flip-face {
  border-color: rgba(217, 182, 111, .48);
  box-shadow: 0 20px 50px rgba(38, 51, 68, .12);
}

body[data-page="preise"] .stage-flip-toggle:focus-visible {
  outline: 3px solid rgba(217, 182, 111, .42);
  outline-offset: 5px;
  border-radius: 20px;
}

body[data-page="preise"] .stage-flip-eyebrow {
  color: #8d7448;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

body[data-page="preise"] .stage-flip-back .stage-flip-eyebrow {
  color: #dac9a6;
}

body[data-page="preise"] .stage-flip-face strong {
  color: inherit;
  display: block;
  font-size: clamp(1.18rem, 1.5vw, 1.52rem);
  font-weight: 800;
  line-height: 1.14;
}

body[data-page="preise"] .stage-flip-face span:not(.stage-flip-eyebrow) {
  color: #2f3b4a;
  display: block;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.45;
}

body[data-page="preise"] .stage-flip-back span:not(.stage-flip-eyebrow) {
  color: rgba(255, 250, 242, .82);
}

body[data-page="preise"] .stage-flip-face em {
  align-self: flex-start;
  border: 1px solid rgba(38, 51, 68, .16);
  border-radius: 999px;
  color: #263344;
  font-size: .82rem;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  padding: 8px 11px;
}

body[data-page="preise"] .stage-flip-back em {
  border-color: rgba(255, 250, 242, .28);
  color: #fffaf2;
}

@media (prefers-color-scheme: dark) {
  body[data-page="preise"] .stage-flip-face {
    background: rgba(27, 36, 48, .92);
    border-color: rgba(255, 250, 242, .13);
    color: #fffaf2;
    box-shadow: 0 18px 48px rgba(0, 0, 0, .24);
  }

  body[data-page="preise"] .stage-flip-back {
    background: #fffaf2;
    color: #263344;
  }

  body[data-page="preise"] .stage-flip-face span:not(.stage-flip-eyebrow) {
    color: rgba(255, 250, 242, .78);
  }

  body[data-page="preise"] .stage-flip-back span:not(.stage-flip-eyebrow) {
    color: #44505e;
  }

  body[data-page="preise"] .stage-flip-face em {
    border-color: rgba(255, 250, 242, .22);
    color: #fffaf2;
  }

  body[data-page="preise"] .stage-flip-back em {
    border-color: rgba(38, 51, 68, .16);
    color: #263344;
  }
}

@media (max-width: 980px) {
  body[data-page="preise"] .stage-flip-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  body[data-page="preise"] .stage-flip-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="preise"] .stage-flip-card,
  body[data-page="preise"] .stage-flip-toggle,
  body[data-page="preise"] .stage-flip-face {
    min-height: 210px;
  }
}

@media (prefers-reduced-motion: reduce) {
  body[data-page="preise"] .stage-flip-face {
    transition: none;
  }
}

/* NIKARI v164 simplified add-on cards */
body[data-page="preise"] .stage-option-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 28px;
}

body[data-page="preise"] .stage-option-card {
  background: rgba(255, 255, 255, .92);
  border: 1px solid rgba(38, 51, 68, .14);
  border-radius: 18px;
  box-shadow: 0 16px 42px rgba(38, 51, 68, .08);
  color: #263344;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 220px;
  padding: 24px;
}

body[data-page="preise"] .stage-option-card span {
  color: #8d7448;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

body[data-page="preise"] .stage-option-card h3 {
  color: #263344;
  font-size: clamp(1.18rem, 1.5vw, 1.46rem);
  font-weight: 800;
  line-height: 1.14;
  margin: 0;
}

body[data-page="preise"] .stage-option-card p {
  color: #2f3b4a;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.45;
  margin: 0;
}

body[data-page="preise"] .stage-option-card strong {
  border-top: 1px solid rgba(38, 51, 68, .1);
  color: #263344;
  font-size: .9rem;
  font-weight: 800;
  margin-top: auto;
  padding-top: 14px;
}

body[data-page="preise"] .stage-module-note {
  margin-top: 18px;
}

@media (prefers-color-scheme: dark) {
  body[data-page="preise"] .stage-option-card {
    background: rgba(27, 36, 48, .92);
    border-color: rgba(255, 250, 242, .13);
    color: #fffaf2;
    box-shadow: 0 18px 48px rgba(0, 0, 0, .24);
  }

  body[data-page="preise"] .stage-option-card span {
    color: #dac9a6;
  }

  body[data-page="preise"] .stage-option-card h3,
  body[data-page="preise"] .stage-option-card strong {
    color: #fffaf2;
  }

  body[data-page="preise"] .stage-option-card p {
    color: rgba(255, 250, 242, .78);
  }

  body[data-page="preise"] .stage-option-card strong {
    border-color: rgba(255, 250, 242, .14);
  }
}

@media (max-width: 980px) {
  body[data-page="preise"] .stage-option-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  body[data-page="preise"] .stage-option-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="preise"] .stage-option-card {
    min-height: 0;
  }
}


/* nikari-2026-06-03-sommer-systems-align-v1 */
body[data-page="preise"] {
  --color-bg: #fbfaf7;
  --color-brand-blue: #113f59;
  --color-gold: #c8ab72;
  --color-brand-blue-soft: rgba(17, 63, 89, 0.08);
  --color-brand-blue-line: rgba(17, 63, 89, 0.18);
  background:
    linear-gradient(180deg, rgba(255,255,255,.86), rgba(251,250,247,.96)),
    #fbfaf7;
}

body[data-page="preise"] .site-header {
  background: rgba(251, 250, 247, .92);
}

body[data-page="preise"] .button.primary,
body[data-page="preise"] .nav-cta {
  background: #113f59;
  border-color: #113f59;
  color: #fff;
  box-shadow: 0 14px 30px rgba(17, 63, 89, .16);
}

body[data-page="preise"] .button.secondary {
  border-color: rgba(17, 63, 89, .24);
  color: #113f59;
  background: rgba(255,255,255,.74);
}

body[data-page="preise"] .kicker,
body[data-page="preise"] .eyebrow,
body[data-page="preise"] .price-badge {
  color: #5f6f5d;
}

body[data-page="preise"] .price-card,
body[data-page="preise"] .stage-option-card,
body[data-page="preise"] .plain-explainer,
body[data-page="preise"] .data-room-photo-panel,
body[data-page="preise"] .comparison-card {
  border-radius: 8px;
}

body[data-page="preise"] .stage-matrix .is-featured-cell,
body[data-page="preise"] .comparison-card.is-featured {
  background: rgba(17, 63, 89, .055);
  border-color: rgba(17, 63, 89, .20);
}

body[data-page="preise"] .stage-matrix .comparison-matrix-head .is-featured-cell {
  background: #113f59;
  color: #fff;
}

body[data-page="preise"] .data-room-photo-tags span {
  background: rgba(251, 250, 247, .88);
  color: #113f59;
  border: 1px solid rgba(17, 63, 89, .18);
}
