:root {
  --bg: #07111f;
  --panel: #0f2235;
  --panel2: #132c45;
  --text: #eef6fb;
  --muted: #a9bed0;
  --line: rgba(255,255,255,.12);
  --accent: #7ce3ff;
  --accent2: #9af7c6;
  --warm: #ffd166;
  --danger: #ff8f8f;
  --ok: #9af7c6;
  --white: #ffffff;
  --shadow: 0 22px 70px rgba(0,0,0,.35);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background: radial-gradient(circle at top left, #17395b, transparent 34rem), radial-gradient(circle at 70% 5%, #0d776a, transparent 30rem), var(--bg);
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
.container { width: min(1160px, calc(100% - 40px)); margin: 0 auto; }
.nav { position: sticky; top: 0; z-index: 10; backdrop-filter: blur(18px); background: rgba(7, 17, 31, .82); border-bottom: 1px solid var(--line); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; min-height: 76px; gap: 18px; }
.logo { display: flex; align-items: center; gap: 12px; font-weight: 800; letter-spacing: -.02em; }
.logo-mark { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 14px; background: linear-gradient(135deg, var(--accent), var(--accent2)); color: #06101c; box-shadow: 0 10px 30px rgba(124,227,255,.22); font-size: 14px; }
.nav-links { display: flex; flex-wrap: wrap; gap: 18px; color: var(--muted); font-size: 15px; align-items: center; }
.nav-links a:hover { color: var(--white); }
.nav-toggle { display: none; border: 1px solid var(--line); color: var(--text); background: rgba(255,255,255,.07); border-radius: 999px; padding: 10px 14px; font: inherit; }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 12px 18px; border-radius: 999px; background: linear-gradient(135deg, var(--accent), var(--accent2)); color: #06101c; font-weight: 800; border: 0; box-shadow: 0 12px 35px rgba(124,227,255,.20); cursor: pointer; font: inherit; }
.btn.secondary { background: rgba(255,255,255,.08); color: var(--text); border: 1px solid var(--line); box-shadow: none; }
.btn.small { padding: 10px 14px; font-size: 14px; }
.text-link { color: #bff4ff; font-weight: 800; }
.hero { padding: 90px 0 70px; }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr); gap: 42px; align-items: center; }
.badge, .pill { display: inline-flex; gap: 8px; align-items: center; padding: 8px 12px; border-radius: 999px; background: rgba(124,227,255,.10); border: 1px solid rgba(124,227,255,.24); color: #c6f6ff; font-weight: 700; font-size: 14px; }
.pill { color: #092033; background: rgba(154,247,198,.9); border: 0; margin-bottom: 14px; }
h1 { font-size: clamp(42px, 7vw, 76px); line-height: .96; margin: 22px 0 20px; letter-spacing: -.055em; }
h2 { font-size: clamp(30px, 4.5vw, 48px); line-height: 1.06; margin: 0 0 18px; letter-spacing: -.04em; }
h3 { margin: 0 0 10px; font-size: 22px; line-height: 1.15; }
p { margin: 0 0 16px; }
p.lead { color: #d7e7f2; font-size: 20px; max-width: 820px; }
.muted { color: var(--muted); }
.actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 30px; }
.actions.vertical { flex-direction: column; align-items: stretch; }
.card, .mockup, .feature, .step, .example, .price-card, .contact-card, .report-card, .intro-card, .question-card, .sticky-card, .architecture-card, .result-box { border: 1px solid var(--line); background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04)); border-radius: 28px; box-shadow: var(--shadow); }
.mockup { padding: 22px; }
.mock-top { display: flex; gap: 8px; padding: 8px 0 18px; }
.dot { width: 11px; height: 11px; border-radius: 50%; background: rgba(255,255,255,.28); }
.dashboard { display: grid; gap: 14px; }
.dash-row { display: grid; grid-template-columns: 1fr auto; gap: 18px; padding: 16px; background: rgba(7,17,31,.62); border: 1px solid var(--line); border-radius: 18px; }
.dash-row strong { display: block; }
.dash-row span { color: var(--muted); font-size: 14px; }
.status { color: #06101c; background: var(--accent2); border-radius: 999px; padding: 6px 10px; font-weight: 800; font-size: 13px; align-self: start; }
.status.warn { background: var(--warm); }
.status.danger { background: var(--danger); }
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-top: 22px; }
.stat { padding: 18px; background: rgba(255,255,255,.06); border: 1px solid var(--line); border-radius: 22px; }
.stat b { display: block; font-size: 28px; }
.stat span { color: var(--muted); font-size: 14px; }
.output-list { display: grid; gap: 12px; margin-top: 20px; }
.output-list div { padding: 14px 16px; border-radius: 16px; background: rgba(255,255,255,.06); border: 1px solid var(--line); }
.section { padding: 72px 0; }
.section.light { background: #f5f9fc; color: #092033; }
.section.light p, .section.light .muted { color: #53687a; }
.section-head { display: flex; align-items: end; justify-content: space-between; gap: 30px; margin-bottom: 28px; }
.section-head p { max-width: 720px; color: var(--muted); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.align-center { align-items: center; }
.feature, .price-card, .report-card { padding: 28px; box-shadow: none; }
.feature .icon { width: 50px; height: 50px; border-radius: 16px; display: grid; place-items: center; background: rgba(124,227,255,.12); margin-bottom: 16px; color: var(--accent); font-weight: 900; }
.section.light .feature .icon { color: #0b6d84; background: rgba(11,109,132,.12); }
.feature p, .example p, .step p, .price-card p { color: var(--muted); margin: 0 0 14px; }
.section.light .price-card, .section.light .feature, .section.light .contact-card { background: #fff; border-color: rgba(9,32,51,.10); color: #092033; }
.price-card ul { padding-left: 20px; color: var(--muted); }
.highlight-free { outline: 2px solid rgba(154,247,198,.42); }
.footer { padding: 36px 0; border-top: 1px solid var(--line); color: var(--muted); }
.footer-grid { display: grid; grid-template-columns: 1fr auto; gap: 20px; align-items: start; }
.footer p { max-width: 700px; margin-top: 6px; }
.footer-links { display: flex; gap: 16px; flex-wrap: wrap; }
.footer-links a:hover { color: var(--white); }
.page-hero { padding: 70px 0 45px; }
.compact-hero { padding-bottom: 28px; }
.page-hero h1 { max-width: 980px; }
.form { display: grid; gap: 14px; }
.input, textarea, select { width: 100%; border: 1px solid rgba(9,32,51,.16); border-radius: 16px; padding: 14px 16px; font: inherit; background: #fff; color: #092033; }
textarea { min-height: 150px; resize: vertical; }
.contact-card { padding: 30px; background: #fff; color: #092033; box-shadow: none; }
.dark-card { background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04)); color: var(--text); }
.dark-card p { color: var(--muted); }
.notice { padding: 18px; border-left: 4px solid var(--warm); background: rgba(255,209,102,.12); border-radius: 16px; color: #f6d890; margin-top: 18px; }
.section.light .notice { color: #714c00; }
.small-notice { font-size: 13px; padding: 14px; }
.check-list { padding-left: 0; list-style: none; display: grid; gap: 10px; margin: 18px 0; }
.check-list li { position: relative; padding-left: 28px; color: var(--muted); }
.section.light .check-list li, .light-list li { color: #53687a; }
.check-list li::before { content: '✓'; position: absolute; left: 0; top: 0; color: var(--accent2); font-weight: 900; }
.flow { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
.step { padding: 20px; box-shadow: none; position: relative; }
.step small { display: inline-grid; place-items: center; width: 32px; height: 32px; border-radius: 50%; background: var(--accent); color: #06101c; font-weight: 900; margin-bottom: 12px; }
.architecture-card { padding: 24px; box-shadow: none; display: grid; gap: 14px; background: #fff; color: #092033; border-color: rgba(9,32,51,.10); }
.arch-line { border: 1px solid rgba(9,32,51,.12); background: #f8fbfd; border-radius: 18px; padding: 16px; }
.arch-line strong { display:block; }
.arch-line span { color:#53687a; }
.arch-arrow { text-align:center; color:#53687a; font-size:22px; }
.demo-layout { display: grid; grid-template-columns: 300px minmax(0,1fr); gap: 24px; align-items: start; }
.demo-aside { position: relative; }
.sticky-card { position: sticky; top: 100px; padding: 22px; box-shadow: none; }
.intro-card { padding: 26px; margin-bottom: 18px; box-shadow: none; }
.question-list { display: grid; gap: 18px; }
.question-card { padding: 24px; box-shadow: none; }
.question-top { display: grid; grid-template-columns: 1fr auto; gap: 18px; align-items: start; }
.question-kicker { color: var(--accent); font-weight: 800; font-size: 13px; text-transform: uppercase; letter-spacing: .06em; }
.help-btn { border: 1px solid rgba(124,227,255,.36); background: rgba(124,227,255,.10); color: #c6f6ff; border-radius: 999px; padding: 8px 12px; font: inherit; font-weight: 800; cursor: pointer; }
.help-panel { margin: 16px 0; padding: 16px; background: rgba(124,227,255,.08); border: 1px solid rgba(124,227,255,.18); border-radius: 18px; color: #d7e7f2; }
.help-panel p { margin-bottom: 10px; }
.options { display: grid; gap: 10px; margin-top: 18px; }
.option { display: grid; grid-template-columns: auto 1fr; gap: 12px; align-items: start; padding: 14px 16px; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.05); cursor: pointer; }
.option:hover { background: rgba(255,255,255,.08); }
.option input { margin-top: 4px; accent-color: #7ce3ff; }
.bottom-actions { justify-content: center; margin: 28px 0; }
.result { padding-top: 20px; }
.result-box { padding: 28px; margin-bottom: 18px; box-shadow: none; }
.result-box.green { border-color: rgba(154,247,198,.45); }
.result-box.amber { border-color: rgba(255,209,102,.55); }
.result-box.red, .result-box.error { border-color: rgba(255,143,143,.55); }
.result-header { display: grid; grid-template-columns: 1fr auto; gap: 20px; align-items: center; }
.score-circle { width: 118px; height: 118px; border-radius: 50%; display:grid; place-items:center; background: linear-gradient(135deg, var(--accent), var(--accent2)); color:#06101c; font-weight:900; box-shadow: 0 12px 35px rgba(124,227,255,.20); }
.score-circle span { font-size: 42px; line-height: 1; }
.score-circle small { margin-top: -28px; }
.score-bar { height: 12px; background: rgba(255,255,255,.12); border-radius: 999px; overflow: hidden; }
.section.light .score-bar, .architecture-card .score-bar { background: rgba(9,32,51,.12); }
.score-bar span { display:block; height: 100%; background: linear-gradient(135deg, var(--accent), var(--accent2)); border-radius: inherit; transition: width .3s ease; }
.risk-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.risk-tags span { border: 1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.08); border-radius: 999px; padding: 7px 10px; color: #e8f7ff; font-size: 14px; }
.result-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.result-grid .report-card:first-child { grid-column: 1 / -1; }
.result-actions { justify-content: center; }
.table-wrap { overflow-x: auto; border-radius: 20px; border: 1px solid rgba(9,32,51,.10); }
table { width: 100%; border-collapse: collapse; background: #fff; color: #092033; }
th, td { text-align: left; padding: 14px 16px; border-bottom: 1px solid rgba(9,32,51,.10); vertical-align: top; }
th { background: #edf5f9; font-size: 14px; }
.compact th, .compact td { padding: 12px; }
.text-page { max-width: 860px; }
.text-page h2 { font-size: 28px; margin-top: 32px; }
.source-list { padding-left: 18px; }
.source-list li { margin-bottom: 10px; }
.source-list a { color: #bff4ff; }
@media (max-width: 980px) {
  .hero-grid, .grid-3, .grid-2, .flow, .demo-layout, .result-grid { grid-template-columns: 1fr; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .sticky-card { position: static; }
  .footer-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .nav-inner { align-items: flex-start; flex-direction: column; padding: 14px 0; }
  .nav-toggle { display: inline-flex; }
  .nav-links { display: none; flex-direction: column; align-items: flex-start; width: 100%; padding-bottom: 12px; }
  .nav-links.open { display: flex; }
  .question-top, .result-header { grid-template-columns: 1fr; }
  .score-circle { width: 96px; height: 96px; }
  .score-circle span { font-size: 34px; }
  h1 { font-size: clamp(38px, 12vw, 58px); }
}
@media (max-width: 520px) {
  .stats { grid-template-columns: 1fr; }
  .container { width: min(100% - 28px, 1160px); }
}
@media print {
  .nav, .footer, .demo-aside, .bottom-actions, .result-actions, .question-list, .intro-card, .compact-hero { display:none !important; }
  body { background:#fff; color:#000; }
  .section { padding: 0; }
  .container { width: 100%; }
  .result-box, .report-card { color:#000; border:1px solid #ccc; box-shadow:none; }
  .risk-tags span { color:#000; border:1px solid #ccc; }
}


/* ---- Demo / Pro / Enterprise Erweiterungen ---- */
.nav-links a.active { color: var(--white); }
.hero-note { display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; color:#d7e7f2; }
.hero-note span { border:1px solid var(--line); background:rgba(255,255,255,.06); border-radius:999px; padding:7px 11px; font-size:14px; }
.package-card { position:relative; overflow:hidden; }
.package-card.featured { outline: 2px solid rgba(124,227,255,.36); }
.package-card.enterprise { outline: 2px solid rgba(154,247,198,.40); }
.price-line { margin: 8px 0 14px; font-size: 34px; line-height: 1.1; letter-spacing:-.03em; font-weight:900; color: var(--text); }
.section.light .price-line { color:#092033; }
.price-line small { font-size: 14px; color: var(--muted); font-weight:700; display:block; margin-top:4px; letter-spacing:0; }
.section.light .price-line small { color:#53687a; }
.badge-row { display:flex; gap:10px; flex-wrap:wrap; margin:18px 0; }
.badge-row .mini-badge { border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.07); border-radius:999px; padding:7px 10px; color:#e8f7ff; font-size:14px; }
.section.light .badge-row .mini-badge { border-color:rgba(9,32,51,.12); background:#f2f7fa; color:#092033; }
.detail-list { display:grid; gap:18px; margin-top:24px; }
.detail-item { padding:24px; border:1px solid var(--line); border-radius:24px; background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04)); }
.section.light .detail-item { background:#fff; border-color:rgba(9,32,51,.10); }
.detail-item h3 { display:flex; gap:12px; align-items:flex-start; }
.detail-number { flex:0 0 auto; width:32px; height:32px; border-radius:12px; display:inline-grid; place-items:center; background:linear-gradient(135deg, var(--accent), var(--accent2)); color:#06101c; font-size:15px; font-weight:900; }
.detail-item p { color:var(--muted); }
.section.light .detail-item p { color:#53687a; }
.outcome-box { padding:22px; border-radius:22px; border:1px solid rgba(154,247,198,.32); background:rgba(154,247,198,.08); }
.section.light .outcome-box { background:#eefcf5; color:#092033; border-color:#c9f2dc; }
.outcome-box strong { color:#caffdf; }
.section.light .outcome-box strong { color:#075c37; }
.compare-table { min-width: 860px; }
.compare-table th:first-child, .compare-table td:first-child { width: 40%; }
.compare-table td:not(:first-child), .compare-table th:not(:first-child) { text-align:center; }
.check { display:inline-grid; place-items:center; width:28px; height:28px; border-radius:50%; background:#e8fff2; color:#075c37; font-weight:900; }
.dash { color:#9aa9b4; font-weight:900; }
.optional { display:inline-block; border-radius:999px; padding:4px 9px; background:#fff7df; color:#714c00; font-size:13px; font-weight:800; }
.limit { display:inline-block; border-radius:999px; padding:4px 9px; background:#edf5f9; color:#092033; font-size:13px; font-weight:800; }
.workflow-mini { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-top:22px; }
.workflow-mini .step { background:rgba(255,255,255,.06); }
.section.light .workflow-mini .step { background:#fff; border-color:rgba(9,32,51,.10); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.consent { display:grid; grid-template-columns:auto 1fr; gap:10px; align-items:start; color:#53687a; font-size:14px; }
.consent input { margin-top:5px; }
.honeypot { position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.contact-grid { display:grid; grid-template-columns:minmax(0,.9fr) minmax(340px,1.1fr); gap:24px; align-items:start; }
.process-list { counter-reset:item; display:grid; gap:14px; margin-top:18px; }
.process-list div { counter-increment:item; padding:18px; border:1px solid rgba(9,32,51,.10); border-radius:18px; background:#fff; }
.process-list div::before { content: counter(item); display:inline-grid; place-items:center; width:30px; height:30px; border-radius:50%; background:#092033; color:#fff; font-weight:900; margin-right:10px; }
.report-preview-list { display:grid; gap:12px; }
.report-preview-list div { padding:14px 16px; border:1px solid var(--line); border-radius:16px; background:rgba(255,255,255,.06); }
.section.light .report-preview-list div { border-color:rgba(9,32,51,.10); background:#fff; }
.callout-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.callout { padding:18px; border:1px solid var(--line); border-radius:18px; background:rgba(255,255,255,.06); }
.callout b { display:block; font-size:24px; line-height:1; }
.callout span { color:var(--muted); font-size:14px; }
.section.light .callout { border-color:rgba(9,32,51,.10); background:#fff; }
.section.light .callout span { color:#53687a; }
.faq { display:grid; gap:14px; }
.faq details { border:1px solid var(--line); border-radius:18px; padding:18px; background:rgba(255,255,255,.06); }
.faq summary { cursor:pointer; font-weight:900; }
.faq p { margin-top:12px; color:var(--muted); }
.section.light .faq details { background:#fff; border-color:rgba(9,32,51,.10); }
.section.light .faq p { color:#53687a; }
@media (max-width: 980px) {
  .workflow-mini, .contact-grid, .callout-grid, .form-row { grid-template-columns:1fr; }
}
@media print {
  .contact-card, .actions, .nav, .footer { display:none !important; }
}


/* ---- CheckCom Anpassungen ---- */
.lang-switch { display:inline-flex; align-items:center; gap:6px; border:1px solid var(--line); background:rgba(255,255,255,.06); border-radius:999px; padding:5px 8px; color:#d7e7f2; font-weight:800; }
.lang-switch a, .lang-switch span { padding:3px 6px; border-radius:999px; }
.lang-switch span { background:linear-gradient(135deg, var(--accent), var(--accent2)); color:#06101c; }
.resource-grid { display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:18px; }
.source-card { border:1px solid var(--line); background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04)); border-radius:24px; padding:24px; box-shadow:none; }
.source-card p { color:var(--muted); }
.source-card h3 { font-size:20px; }
.copyright { font-size:14px; color:#d7e7f2; }
.footer strong { color:#fff; }
label { display:grid; gap:6px; font-weight:800; }
label .input, label textarea, label select { font-weight:400; }
@media (max-width: 980px) { .resource-grid { grid-template-columns:1fr; } }


:root {
  --bg: #ffffff;
  --panel: #ffffff;
  --panel2: #f4f6f8;
  --text: #1f2937;
  --heading: #101828;
  --muted: #667085;
  --lead: #475467;
  --line: rgba(16, 24, 40, .12);
  --accent: #155eef;
  --accent2: #12b76a;
  --warm: #f79009;
  --danger: #d92d20;
  --ok: #12b76a;
  --white: #101828;
  --shadow: 0 16px 42px rgba(16,24,40,.08);
  --card-shadow: 0 10px 28px rgba(16,24,40,.07);
  --nav-shadow: 0 4px 16px rgba(16,24,40,.06);
  --soft-glow: 0 10px 24px rgba(21,94,239,.13);
  --nav-bg: rgba(255,255,255,.94);
  --nav-muted: #667085;
  --surface: #f8fafc;
  --section-bg: #ffffff;
  --section-light-bg: #f8fafc;
  --card-bg: #ffffff;
  --mockup-bg: #ffffff;
  --logo-bg: linear-gradient(135deg, #155eef, #12b76a);
  --logo-text: #ffffff;
  --btn-bg: #155eef;
  --btn-text: #ffffff;
  --btn-shadow: 0 12px 24px rgba(21,94,239,.18);
  --badge-bg: #f2f4f7;
  --badge-border: #eaecf0;
  --badge-text: #344054;
  --icon-bg: #eff4ff;
  --icon-text: #155eef;
  --link: #155eef;
  --check: #039855;
  --dot: rgba(16,24,40,.22);
  --status-bg: #dcfae6;
  --status-text: #05603a;
  --outline-strong: rgba(21,94,239,.22);
  --outline-soft: rgba(18,183,106,.24);
  --notice-bg: #fffaeb;
  --notice-text: #93370d;
  --success-bg: #ecfdf3;
  --success-border: #abefc6;
  --success-text: #067647;
  --help-bg: #f9fafb;
  --option-hover: #f9fafb;
  --input-border: #d0d5dd;
  --focus: rgba(21,94,239,.16);
  --meter-bg: #eaecf0;
  --table-head: #f2f4f7;
  --optional-bg: #fffaeb;
  --optional-text: #93370d;
  --limit-bg: #f2f4f7;
  --code-bg: #101828;
  --code-text: #f9fafb;
  --footer-bg: #ffffff;
}
body { background: var(--bg); }
.hero { padding-top: 78px; }
.card, .mockup, .feature, .step, .example, .price-card, .contact-card, .report-card, .intro-card, .question-card, .sticky-card, .architecture-card, .result-box, .source-card, .detail-item, .faq details, .callout { border-radius: 22px; }
.btn { border-radius: 12px; }
.btn.secondary { background: #ffffff; }
.badge, .pill, .lang-switch, .hero-note span { border-radius: 12px; }


/* ============================================================
   CheckCom Designvariante: Minimal White
   Diese Datei ist eine komplette CSS-Datei und kann testweise
   als style.css verwendet werden. Sie basiert auf dem bestehenden
   Layout, hellt aber Farben, Flächen und Kontraste auf.
   ============================================================ */
html { background: var(--bg); }
body { color: var(--text); }
.nav { background: var(--nav-bg); border-bottom: 1px solid var(--line); box-shadow: var(--nav-shadow); }
.logo { color: var(--heading); }
.logo-mark { color: var(--logo-text); background: var(--logo-bg); box-shadow: var(--soft-glow); }
.nav-links { color: var(--nav-muted); }
.nav-links a:hover, .nav-links a.active { color: var(--heading); }
.nav-toggle { color: var(--heading); background: var(--surface); border-color: var(--line); }
.lang-switch { color: var(--heading); background: var(--surface); border-color: var(--line); }
.lang-switch span { color: var(--logo-text); background: var(--logo-bg); }
.btn { color: var(--btn-text); background: var(--btn-bg); box-shadow: var(--btn-shadow); }
.btn.secondary { color: var(--heading); background: var(--surface); border: 1px solid var(--line); box-shadow: none; }
.text-link, .source-list a { color: var(--link); }
.badge, .pill { background: var(--badge-bg); border: 1px solid var(--badge-border); color: var(--badge-text); }
.pill { margin-bottom: 14px; }
h1, h2, h3, strong, .footer strong { color: var(--heading); }
p.lead { color: var(--lead); }
.muted, .section-head p, .feature p, .example p, .step p, .price-card p, .detail-item p, .source-card p, .dash-row span, .stat span, .callout span, .faq p { color: var(--muted); }
.hero-note { color: var(--muted); }
.hero-note span { background: var(--surface); border-color: var(--line); color: var(--muted); }
.card, .mockup, .feature, .step, .example, .price-card, .contact-card, .report-card, .intro-card, .question-card, .sticky-card, .architecture-card, .result-box, .source-card, .detail-item, .faq details, .callout { background: var(--card-bg); border-color: var(--line); box-shadow: var(--card-shadow); color: var(--text); }
.price-card.featured, .package-card.featured { outline-color: var(--outline-strong); }
.price-card.enterprise, .package-card.enterprise { outline-color: var(--outline-soft); }
.highlight-free { outline-color: var(--outline-soft); }
.stat, .output-list div, .report-preview-list div, .workflow-mini .step, .option, .arch-line { background: var(--surface); border-color: var(--line); color: var(--text); }
.mockup { background: var(--mockup-bg); }
.dash-row { background: var(--surface); border-color: var(--line); }
.dot { background: var(--dot); }
.status { background: var(--status-bg); color: var(--status-text); }
.status.warn { background: var(--warm); color: var(--status-text); }
.status.danger { background: var(--danger); color: #fff; }
.output-list div { color: var(--heading); }
.stats .stat b, .callout b { color: var(--heading); }
.section { background: var(--section-bg); }
.section.light { background: var(--section-light-bg); color: var(--text); }
.section.light p, .section.light .muted, .section.light .feature p, .section.light .price-card p, .section.light .detail-item p, .section.light .source-card p, .section.light .faq p, .section.light .check-list li, .light-list li { color: var(--muted); }
.section.light .price-card, .section.light .feature, .section.light .contact-card, .section.light .detail-item, .section.light .source-card, .section.light .report-card, .section.light .workflow-mini .step, .section.light .callout, .section.light .faq details { background: var(--card-bg); border-color: var(--line); color: var(--text); box-shadow: var(--card-shadow); }
.section.light .feature .icon, .feature .icon { color: var(--icon-text); background: var(--icon-bg); }
.price-line, .section.light .price-line { color: var(--heading); }
.price-line small, .section.light .price-line small { color: var(--muted); }
.check-list li { color: var(--muted); }
.check-list li::before { color: var(--check); }
.step small, .detail-number, .score-circle { color: var(--logo-text); background: var(--logo-bg); box-shadow: var(--soft-glow); }
.notice { background: var(--notice-bg); border-left-color: var(--warm); color: var(--notice-text); }
.section.light .notice { color: var(--notice-text); }
.outcome-box, .section.light .outcome-box { background: var(--success-bg); border-color: var(--success-border); color: var(--text); }
.outcome-box strong, .section.light .outcome-box strong { color: var(--success-text); }
.input, textarea, select { background: #fff; color: var(--heading); border-color: var(--input-border); box-shadow: none; }
.input:focus, textarea:focus, select:focus { outline: 3px solid var(--focus); border-color: var(--accent); }
.contact-card { background: var(--card-bg); color: var(--text); }
label { color: var(--heading); }
.consent { color: var(--muted); }
.help-btn { color: var(--link); background: var(--badge-bg); border-color: var(--badge-border); }
.help-panel { color: var(--lead); background: var(--help-bg); border-color: var(--badge-border); }
.option:hover { background: var(--option-hover); }
.option input { accent-color: var(--accent); }
.score-bar { background: var(--meter-bg); }
.score-bar span { background: var(--logo-bg); }
.risk-tags span, .badge-row .mini-badge, .section.light .badge-row .mini-badge { background: var(--surface); border-color: var(--line); color: var(--muted); }
.table-wrap { border-color: var(--line); }
table { background: var(--card-bg); color: var(--text); }
th { background: var(--table-head); color: var(--heading); }
th, td { border-bottom-color: var(--line); }
.check { background: var(--success-bg); color: var(--success-text); }
.optional { background: var(--optional-bg); color: var(--optional-text); }
.limit { background: var(--limit-bg); color: var(--heading); }
.process-list div { background: var(--card-bg); border-color: var(--line); }
.process-list div::before { background: var(--heading); color: #fff; }
.code-box { background: var(--code-bg); color: var(--code-text); border-color: var(--line); }
.footer { background: var(--footer-bg); color: var(--muted); border-top-color: var(--line); }
.footer a:hover, .footer-links a:hover { color: var(--heading); }
.copyright { color: var(--muted); }
.dark-card { background: var(--card-bg); color: var(--text); }
.dark-card p { color: var(--muted); }
.resource-grid .source-card { background: var(--card-bg); }
@media print { body { background:#fff !important; color:#000 !important; } }






/* ============================================================
   CheckCom Mobile + SEO Launch Anpassungen mobile-seo-2026-05-20-6
   ============================================================ */
.nav-inner { flex-direction: row !important; align-items: center !important; justify-content: space-between !important; position: relative; min-height: 76px; }
.nav-links { margin-left: auto; }
.nav-actions, .nav-controls { display: inline-flex; align-items: center; justify-content: flex-end; gap: 10px; margin-left: 12px; flex: 0 0 auto; }
.nav-actions .lang-switch, .nav-lang { display: inline-flex; flex-shrink: 0; }
.nav-toggle { flex-shrink: 0; }
.hero-badge, .hero-badge-green { background: #ecfdf3 !important; border-color: #abefc6 !important; color: #067647 !important; }
.hero-disclaimer, .plain-note { margin-top: 18px; max-width: 780px; color: var(--muted); font-size: 15px; line-height: 1.65; }
.hero-disclaimer strong, .plain-note strong { color: var(--heading); }
.stats-3 { grid-template-columns: repeat(3, 1fr); }
.btn.green, .start-btn { background: #12b76a !important; color: #ffffff !important; box-shadow: 0 10px 22px rgba(18,183,106,.18) !important; white-space: nowrap; }
.card-cta-row { display: flex; justify-content: flex-end; margin-top: 20px; }
.package-link-card, .linked-card { color: inherit; text-decoration: none; cursor: pointer; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.package-link-card:hover, .linked-card:hover { transform: translateY(-2px); border-color: rgba(18,183,106,.42); box-shadow: 0 18px 42px rgba(16,24,40,.11); }
.package-card-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 12px; }
.package-card-top .pill { margin-bottom: 0; }
.workflow-link { color: inherit; text-decoration: none; cursor: pointer; transition: transform .18s ease, border-color .18s ease; }
.workflow-link:hover { transform: translateY(-2px); border-color: rgba(18,183,106,.42); }
.nav-links a { white-space: nowrap; }
.package-card h3 a { color: inherit; text-decoration: none; }
.package-card h3 a:hover { color: var(--link); }
.linked-card:focus-visible, .package-link-card:focus-visible, .text-link:focus-visible, .btn:focus-visible, .nav-links a:focus-visible, .lang-switch a:focus-visible, .nav-toggle:focus-visible { outline: 3px solid var(--focus); outline-offset: 3px; }
@media (max-width: 980px) {
  .nav-inner { flex-direction: row !important; align-items: center !important; padding: 12px 0; }
  .stats-3 { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .nav { overflow: visible; }
  .nav-inner { min-height: 72px; flex-wrap: nowrap !important; gap: 10px; }
  .logo { min-width: 0; flex: 1 1 auto; }
  .logo span:last-child { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .logo-mark { width: 44px; height: 44px; border-radius: 14px; }
  .nav-actions, .nav-controls { order: 2; margin-left: auto; }
  .nav-toggle { display: inline-flex; align-items: center; justify-content: center; margin-left: 0; min-height: 42px; }
  .nav-links { position: absolute !important; top: calc(100% + 8px); left: 0; right: 0; z-index: 50; width: auto !important; margin-left: 0 !important; padding: 14px !important; border: 1px solid var(--line); border-radius: 18px; background: #ffffff; box-shadow: 0 18px 40px rgba(16,24,40,.14); flex-direction: column; align-items: flex-start; gap: 8px; order: 3; }
  .nav-links.open { display: flex; }
  .nav-links a { width: 100%; padding: 9px 10px; border-radius: 10px; }
  .nav-links a:hover, .nav-links a.active { background: var(--surface); }
  .lang-switch, .lang-switch.nav-lang { display: inline-flex; padding: 4px 6px; font-size: 14px; }
  .hero { padding: 56px 0 48px; }
  .page-hero { padding-top: 48px; }
  h1 { font-size: clamp(36px, 10.4vw, 54px); letter-spacing: -.045em; }
  p.lead { font-size: 18px; }
  .actions .btn { width: 100%; justify-content: center; white-space: normal; }
  .card-cta-row .btn { width: auto; }
  .package-card-top { align-items: center; }
  .start-btn { width: auto !important; padding: 10px 12px; font-size: 14px; }
  .hero-disclaimer, .plain-note { font-size: 14px; }
}
@media (max-width: 420px) {
  .container { width: min(100% - 28px, 1160px); }
  .logo { gap: 10px; }
  .logo-mark { width: 40px; height: 40px; }
  .nav-actions, .nav-controls { gap: 6px; }
  .nav-toggle { padding: 9px 12px; }
  .lang-switch, .lang-switch.nav-lang { gap: 3px; }
  .lang-switch a, .lang-switch span, .lang-switch.nav-lang a, .lang-switch.nav-lang span { padding: 3px 5px; }
}


/* ============================================================
   CheckCom EU AI Act Update eu-ai-act-update-2026-05-21-1
   ============================================================ */
.no-underline, .no-underline:hover, .compare-head-link, .compare-head-link:hover, .table-link, .table-link:hover { text-decoration: none !important; }
.compare-head-link { color: var(--heading); font-weight: 900; display: inline-flex; align-items: center; justify-content: center; gap: 6px; }
.compare-head-link::after { content: '↗'; font-size: 12px; opacity: .55; }
.table-link { color: var(--link); font-weight: 800; }
.price-note { margin: 16px 0 0; color: var(--muted); font-weight: 800; }
.resource-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.source-card { padding: 24px; border: 1px solid var(--line); border-radius: 22px; background: var(--card-bg); box-shadow: var(--card-shadow); }
.source-card h3 { font-size: 20px; }
.source-card p { color: var(--muted); }
.detail-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.detail-item .outcome-box { margin-top: 14px; }
.report-preview-list { display: grid; gap: 14px; }
.report-preview-list div { padding: 16px; border-radius: 18px; border: 1px solid var(--line); background: var(--surface); }
.process-list { display: grid; gap: 12px; margin-top: 18px; }
.process-list div { padding: 16px; border: 1px solid var(--line); border-radius: 18px; background: var(--card-bg); }
.process-list span { color: var(--muted); }
.badge-row { display: flex; flex-wrap: wrap; gap: 10px; margin: 18px 0; }
.mini-badge { display: inline-flex; padding: 7px 10px; border: 1px solid var(--line); border-radius: 999px; background: var(--surface); color: var(--muted); font-weight: 700; font-size: 13px; }
.result-header { display: flex; justify-content: space-between; gap: 22px; align-items: flex-start; }
@media (max-width: 980px) { .resource-grid, .detail-list { grid-template-columns: 1fr; } }
@media (max-width: 720px) { .compare-table { min-width: 980px; } .result-header { flex-direction: column; } }

/* ============================================================
   CheckCom Vergleichstabelle Layout-Fix table-fix-2026-05-21-2
   Korrigiert die Darstellung langer Häkchen-/Hinweis-Texte in der Tabelle.
   ============================================================ */
.table-wrap {
  overflow-x: auto;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: var(--card-bg);
  box-shadow: var(--card-shadow);
  -webkit-overflow-scrolling: touch;
}
.compare-table {
  width: 100%;
  min-width: 1120px;
  table-layout: fixed;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--card-bg);
  color: var(--text);
}
.compare-table th,
.compare-table td {
  padding: 15px 16px;
  border-bottom: 1px solid var(--line);
  vertical-align: middle;
  font-size: 15px;
  line-height: 1.42;
  overflow-wrap: break-word;
  hyphens: auto;
}
.compare-table thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--table-head);
  color: var(--heading);
  font-size: 14px;
  letter-spacing: .01em;
}
.compare-table th:first-child,
.compare-table td:first-child {
  width: 34%;
  text-align: left;
}
.compare-table th:not(:first-child),
.compare-table td:not(:first-child) {
  width: 22%;
  text-align: center;
}
.compare-table tbody tr:nth-child(even) td { background: #fcfcfd; }
.compare-table tbody tr:hover td { background: #f8fafc; }
.compare-table tbody tr:last-child td { border-bottom: 0; }
.compare-table td:first-child { color: var(--heading); font-weight: 650; }
.compare-head-link,
.compare-head-link:hover,
.table-link,
.table-link:hover { text-decoration: none !important; }
.compare-head-link { color: var(--heading); font-weight: 900; }
.table-link { color: var(--link); font-weight: 850; }
.yes-icon,
.compare-table .yes-icon {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: var(--success-bg);
  color: var(--success-text);
  font-weight: 950;
  line-height: 1;
}
.yes-badge,
.info-badge,
.price-badge,
.optional-badge,
.compare-table .limit,
.compare-table .optional {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  max-width: 100%;
  min-height: 30px;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 13px;
  font-weight: 850;
  line-height: 1.25;
  text-align: center;
  white-space: normal;
  overflow-wrap: normal;
  hyphens: none;
}
.yes-badge { background: var(--success-bg); color: var(--success-text); border: 1px solid var(--success-border); }
.info-badge, .compare-table .limit { background: var(--limit-bg); color: var(--heading); border: 1px solid var(--line); }
.price-badge { background: #eff4ff; color: #155eef; border: 1px solid #d1e0ff; }
.optional-badge, .compare-table .optional { background: var(--optional-bg); color: var(--optional-text); border: 1px solid #fedf89; }
.dash, .compare-table .dash { color: #98a2b3; font-weight: 900; font-size: 20px; line-height: 1; }
.compare-table .check {
  display: inline-grid;
  place-items: center;
  width: 28px;
  min-width: 28px;
  height: 28px;
  border-radius: 999px;
  padding: 0;
  background: var(--success-bg);
  color: var(--success-text);
  font-weight: 950;
  line-height: 1;
}
.price-note { margin: 16px 0 0; color: var(--heading); font-weight: 850; }
@media (max-width: 720px) {
  .table-wrap { margin-left: -14px; margin-right: -14px; border-radius: 0; border-left: 0; border-right: 0; }
  .compare-table { min-width: 1040px; }
  .compare-table th, .compare-table td { padding: 13px 14px; font-size: 14px; }
}


/* CheckCom AI Omnibus Update ai-omnibus-2026-05-22-1 */
.ai-update-teaser { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.compact-table td { vertical-align: top; }
.text-badge { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; padding: 7px 11px; background: var(--surface); border: 1px solid var(--line); color: var(--text); font-weight: 800; font-size: 13px; line-height: 1.25; }
.text-badge.good { background: rgba(0, 138, 91, .10); color: var(--check); border-color: rgba(0, 138, 91, .18); }
.text-badge.warn { background: rgba(245, 158, 11, .12); color: #92400e; border-color: rgba(245, 158, 11, .22); }
.text-badge.danger { background: rgba(185, 28, 28, .09); color: #991b1b; border-color: rgba(185, 28, 28, .18); }
.timeline-list { display: grid; gap: 14px; }
.timeline-item { display: grid; grid-template-columns: 190px 1fr; gap: 20px; align-items: start; padding: 18px 20px; border: 1px solid var(--line); border-radius: 18px; background: var(--card-bg); box-shadow: var(--card-shadow); }
.timeline-item strong { color: var(--link); }
.timeline-item span { color: var(--muted); }
@media (max-width: 720px) {
  .timeline-item { grid-template-columns: 1fr; gap: 6px; }
  .compact-table td { min-width: 220px; }
}


/* ============================================================
   CheckCom LiteVersion Update liteversion-2026-05-22-2
   ============================================================ */
.nav-links a.nav-lite {
  background: #ecfdf3;
  color: #067647 !important;
  border: 1px solid #abefc6;
  padding: 7px 10px;
  border-radius: 999px;
  font-weight: 900;
}
.nav-links a.nav-lite.active { background: #12b76a; color: #fff !important; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.stats-4 { grid-template-columns: repeat(4, 1fr); }
.package-card.lite { outline: 2px solid rgba(18,183,106,.36); }
.lite-panel { border-color: rgba(18,183,106,.28); }
.order-card .pill { background: #ecfdf3; color: #067647; border: 1px solid #abefc6; }
.compact-order-form textarea { min-height: 110px; }
.lite-cross-sell { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.compare-table.product-table-4 { min-width: 1320px; }
.compare-table.product-table-4 th:first-child,
.compare-table.product-table-4 td:first-child { width: 28%; }
.compare-table.product-table-4 th:not(:first-child),
.compare-table.product-table-4 td:not(:first-child) { width: 18%; }
.price-badge { white-space: nowrap !important; }
@media (max-width: 1180px) {
  .grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .stats-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .grid-4 { grid-template-columns: 1fr; }
  .stats-4 { grid-template-columns: 1fr; }
  .nav-links a.nav-lite { width: auto; display: inline-flex; }
  .compare-table.product-table-4 { min-width: 1280px; }
}


/* ============================================================
   CheckCom Logo + Lite Version Polish logo-lite-polish-2026-05-22-1
   ============================================================ */
.logo { flex: 0 0 auto; min-width: 0; }
.logo .brand-logo-img {
  display: block;
  height: 44px;
  width: auto;
  max-width: 190px;
  object-fit: contain;
}
.nav-links { gap: 16px; }
.hero-grid { align-items: start; }
.hero-grid > * { min-width: 0; }
.mockup, .dashboard, .dash-row { min-width: 0; }
.dash-row { grid-template-columns: minmax(0, 1fr) auto; }
.dash-row strong, .dash-row span { min-width: 0; overflow-wrap: anywhere; }
.status { white-space: nowrap; }
.hero .stats-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.stat { min-width: 0; overflow-wrap: anywhere; }
.hero-resource-links {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 14px;
}
.hero-resource-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--link);
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 14px;
  font-weight: 850;
  text-decoration: none !important;
}
.hero-resource-links a:hover { border-color: rgba(18,183,106,.35); background: #ecfdf3; color: #067647; }
.package-card .start-btn { white-space: nowrap; }
@media (max-width: 980px) {
  .hero-resource-links { justify-content: flex-start; }
}
@media (max-width: 720px) {
  .logo .brand-logo-img { height: 38px; max-width: 170px; }
  .hero .stats-4 { grid-template-columns: 1fr; }
  .hero-resource-links { margin-top: 4px; }
  .hero-resource-links a { width: 100%; }
}
@media (max-width: 420px) {
  .logo .brand-logo-img { height: 34px; max-width: 150px; }
}

.hero-side { min-width: 0; display: grid; gap: 0; align-content: start; }
.hero-side .hero-resource-links { margin-bottom: 14px; }
@media (max-width: 980px) { .hero-side { gap: 0; } }

/* Logo width refinement */
.logo .brand-logo-img { width: 170px; height: auto; max-height: 42px; }
@media (max-width:720px){ .logo .brand-logo-img { width: 150px; height: auto; max-height: 36px; } }
@media (max-width:420px){ .logo .brand-logo-img { width: 132px; height: auto; max-height: 32px; } }


/* ============================================================
   CheckCom Website Polish + Dokumentenhub site-docs-polish-2026-05-23-1
   - kompakte Vergleichstabellen auf Desktop
   - Dokumentenbibliothek-Karten und Hinweisboxen
   ============================================================ */
.compare-table.product-table-4 {
  width: 100% !important;
  min-width: 0 !important;
  table-layout: fixed !important;
}
.compare-table.product-table-4 th:first-child,
.compare-table.product-table-4 td:first-child {
  width: 24% !important;
}
.compare-table.product-table-4 th:not(:first-child),
.compare-table.product-table-4 td:not(:first-child) {
  width: 19% !important;
}
.compare-table.product-table-4 th,
.compare-table.product-table-4 td {
  padding: 11px 9px !important;
  font-size: 13px !important;
  line-height: 1.34 !important;
}
.compare-table.product-table-4 .yes-badge,
.compare-table.product-table-4 .info-badge,
.compare-table.product-table-4 .text-badge,
.compare-table.product-table-4 .price-badge,
.compare-table.product-table-4 .optional-badge {
  padding: 5px 7px !important;
  font-size: 12px !important;
  line-height: 1.22 !important;
  border-radius: 999px;
}
.compare-table.product-table-4 .price-badge { white-space: normal !important; }
.compare-table.product-table-4 .dash { font-size: 17px !important; }
@media (max-width: 980px) {
  .compare-table.product-table-4 { min-width: 920px !important; }
  .compare-table.product-table-4 th,
  .compare-table.product-table-4 td { padding: 12px 10px !important; font-size: 13px !important; }
}
@media (min-width: 981px) {
  .table-wrap.compact-no-scroll { overflow-x: visible; }
}
.doc-hub-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.doc-hub-card { padding: 22px; border: 1px solid var(--line); border-radius: 22px; background: var(--card-bg); box-shadow: var(--card-shadow); }
.doc-hub-card h3 { font-size: 19px; }
.doc-hub-card p { color: var(--muted); margin-top: 8px; }
.doc-hub-card .mini-badge { margin-bottom: 10px; }
.doc-source-table td { vertical-align: top; }
.doc-update-box { border: 1px solid #abefc6; background: #ecfdf3; color: #065f46; border-radius: 22px; padding: 20px; }
.doc-update-box h3 { color: #064e3b; }
.doc-update-box p { color: #067647; }
.legal-list { display: grid; gap: 12px; }
.legal-list div { padding: 16px; border: 1px solid var(--line); border-radius: 18px; background: var(--surface); }
@media (max-width: 980px) { .doc-hub-grid { grid-template-columns: 1fr; } }


/* ---- AI Visibility Check free area ---- */
.logo.simple-logo { gap: 14px; }
.logo.simple-logo .logo-mark { font-weight: 900; letter-spacing: -.03em; }
.logo.simple-logo .logo-text { display:flex; flex-direction:column; line-height:1.08; }
.logo.simple-logo .logo-text small { color: var(--muted); font-size:12px; font-weight:700; letter-spacing:.02em; }
.nav-actions { display:flex; gap:14px; align-items:center; }
.lang-switch { display:inline-flex; gap:10px; align-items:center; border:1px solid var(--line); border-radius:999px; padding:8px 12px; color:var(--muted); font-size:14px; }
.lang-switch a:hover, .lang-switch span { color: var(--white); font-weight:800; }
.hero-kpis { display:grid; grid-template-columns: repeat(4, 1fr); gap:14px; margin-top:24px; }
.hero-kpis .stat { background: rgba(255,255,255,.05); }
.highlight-panel { padding:28px; border-radius:28px; border:1px solid var(--line); background: linear-gradient(180deg, rgba(124,227,255,.08), rgba(154,247,198,.06)); box-shadow: var(--shadow); }
.module-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:18px; }
.module-card { padding:24px; border-radius:24px; border:1px solid var(--line); background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.04)); box-shadow:none; display:flex; flex-direction:column; gap:12px; }
.module-card .eyebrow { color:#bff4ff; font-size:13px; font-weight:800; text-transform:uppercase; letter-spacing:.06em; }
.module-card p { color: var(--muted); margin:0; }
.module-card .mode { display:inline-flex; align-self:flex-start; padding:6px 10px; border-radius:999px; font-size:13px; font-weight:800; background: rgba(154,247,198,.22); color:#d9ffe9; border:1px solid rgba(154,247,198,.28); }
.module-card .mode.hybrid { background: rgba(255,209,102,.18); color:#ffe8b7; border-color: rgba(255,209,102,.28); }
.module-card .mode.teaser { background: rgba(255,255,255,.09); color:#e8f7ff; border-color: rgba(255,255,255,.18); }
.breadcrumbs { color: var(--muted); font-size:14px; margin-bottom:16px; display:flex; flex-wrap:wrap; gap:8px; }
.breadcrumbs a { color:#bff4ff; }
.module-layout { display:grid; grid-template-columns: 290px minmax(0,1fr); gap:24px; align-items:start; }
.module-layout .sticky-card { top:96px; }
.sidebar-nav { display:grid; gap:10px; }
.sidebar-nav a { padding:10px 12px; border-radius:14px; border:1px solid var(--line); background: rgba(255,255,255,.04); color:var(--muted); font-size:14px; }
.sidebar-nav a.active, .sidebar-nav a:hover { color: var(--white); background: rgba(124,227,255,.08); border-color: rgba(124,227,255,.20); }
.metric-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:14px; }
.metric-card { padding:18px; border-radius:20px; border:1px solid var(--line); background: rgba(255,255,255,.05); }
.metric-card b { display:block; font-size:28px; line-height:1; margin-bottom:6px; }
.metric-card span { color: var(--muted); font-size:14px; }
.callout { padding:20px 22px; border-radius:22px; border:1px solid rgba(124,227,255,.18); background: rgba(124,227,255,.08); margin:18px 0; }
.callout strong { color:#d9f8ff; }
.section.light .callout { background:#eef8fd; color:#092033; border-color:#d5ebf5; }
.section.light .callout strong { color:#0b6d84; }
.data-card { padding:24px; border-radius:24px; border:1px solid var(--line); background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04)); }
.status-pill { display:inline-flex; align-items:center; gap:8px; padding:7px 11px; border-radius:999px; font-size:13px; font-weight:800; border:1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.07); }
.status-pill.ok { background: rgba(154,247,198,.18); border-color: rgba(154,247,198,.28); color:#d9ffe9; }
.status-pill.warn { background: rgba(255,209,102,.18); border-color: rgba(255,209,102,.28); color:#ffe8b7; }
.status-pill.fail { background: rgba(255,143,143,.18); border-color: rgba(255,143,143,.28); color:#ffd6d6; }
.demo-box { margin-top:18px; }
.demo-box .table-wrap, .demo-box table { background: transparent; }
.demo-box .empty { padding:18px; border-radius:18px; border:1px dashed rgba(255,255,255,.18); color: var(--muted); }
.section.light .demo-box .empty { border-color: rgba(9,32,51,.18); color:#53687a; }
.result-shell { display:grid; gap:18px; }
.result-shell .result-header-simple { display:flex; flex-wrap:wrap; gap:12px; align-items:center; justify-content:space-between; }
.kicker { color:#bff4ff; font-size:13px; font-weight:800; text-transform:uppercase; letter-spacing:.06em; }
.small-grid { display:grid; grid-template-columns: repeat(2, 1fr); gap:14px; }
.link-list { display:grid; gap:10px; }
.link-list a { padding:12px 14px; border-radius:16px; border:1px solid var(--line); background: rgba(255,255,255,.04); color:var(--text); }
.form-note { font-size:14px; color: var(--muted); margin-top:12px; }
.loader { display:none; margin-top:16px; color:#d9f8ff; font-weight:700; }
.loader.visible { display:block; }
.notice-soft { padding:14px 16px; border-radius:16px; background: rgba(255,255,255,.05); border:1px solid var(--line); color: var(--muted); }
.hero-form { padding:28px; border-radius:28px; border:1px solid var(--line); background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04)); box-shadow: var(--shadow); }
.hero-form .form-row-3 { display:grid; grid-template-columns: 1fr 1fr 1fr; gap:14px; }
.hero-form label { display:grid; gap:8px; font-weight:700; }
.hero-form .btn { width:100%; }
.demo-summary-box { padding:22px; border-radius:22px; border:1px solid var(--line); background: rgba(255,255,255,.05); }
.table-compact td, .table-compact th { font-size:14px; }
.highlight-list { display:grid; gap:12px; margin:0; padding-left: 0; list-style:none; }
.highlight-list li { padding-left: 26px; position: relative; }
.highlight-list li::before { content:"•"; position:absolute; left:8px; top:0; color: var(--accent2); font-weight:900; }
.section.light .module-card, .section.light .data-card, .section.light .demo-summary-box { background:#fff; color:#092033; border-color:rgba(9,32,51,.10); }
.section.light .module-card p, .section.light .notice-soft, .section.light .metric-card span { color:#53687a; }
.section.light .module-card .eyebrow { color:#0b6d84; }
.section.light .module-card .mode { color:#075c37; }
.section.light .module-card .mode.hybrid { color:#714c00; }
.section.light .module-card .mode.teaser { color:#092033; }
.result-nav-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:14px; }
.result-nav-card { padding:18px; border-radius:20px; border:1px solid var(--line); background: rgba(255,255,255,.05); }
.result-nav-card h3 { font-size:20px; margin-bottom:8px; }
.result-nav-card p { color:var(--muted); }
.score-mini { width:72px; height:72px; border-radius:50%; display:grid; place-items:center; background: linear-gradient(135deg, var(--accent), var(--accent2)); color:#06101c; font-weight:900; font-size:24px; }
.footer .copyright a, .footer .copyright a:visited { color: inherit; text-decoration:none; }
@media (max-width: 1100px){
  .module-grid, .hero-kpis, .metric-grid, .result-nav-grid { grid-template-columns: repeat(2,1fr); }
  .module-layout { grid-template-columns: 1fr; }
}
@media (max-width: 720px){
  .module-grid, .hero-kpis, .metric-grid, .small-grid, .result-nav-grid, .hero-form .form-row-3 { grid-template-columns: 1fr; }
}


/* ============================================================
   AIVC Refresh v2 – stronger contrast, original CheckCom logo,
   softer green inputs and highlighted full-version sidebar
   ============================================================ */
.logo.brand-logo { gap: 12px; align-items: center; }
.logo.brand-logo .brand-logo-img { display:block; width:170px; height:auto; max-height:42px; object-fit:contain; }
.logo.brand-logo .logo-text { display:flex; flex-direction:column; line-height:1.05; }
.logo.brand-logo .logo-text span { font-weight:800; color: var(--heading); font-size:14px; letter-spacing:-.01em; }
.logo.brand-logo .logo-text small { color: #087f5b; font-size:11px; font-weight:800; letter-spacing:.02em; text-transform:uppercase; }

body, .section.light { color: var(--text); }
p, li, .module-card p, .section.light p, .section.light .module-card p, .source-card p, .faq p, .table-note, .muted, .section.light .muted, .sticky-card p, .demo-summary-box p, .detail-item p { color: #344054; }
p.lead { color: #344054; }
h1, h2, h3, h4, strong, .footer strong, .logo, .nav-links a.active { color: var(--heading); }

.badge, .pill { background:#f2f4f7; border-color:#e4e7ec; color:#344054; }
.badge { font-weight:800; }
.pill { font-weight:800; color:#175cd3; background:#eff8ff; border-color:#b2ddff; }

.hero-form, .highlight-panel, .module-card, .sticky-card, .data-card, .demo-summary-box, .source-card, .result-box, .callout, .notice-soft, .metric-card { box-shadow: 0 10px 28px rgba(16,24,40,.07); }
.module-card { background:#fff; border-color:#d0d5dd; }
.module-card .eyebrow { color:#175cd3; font-weight:800; }
.module-card p { color:#344054; }
.module-card .mode { background:#ecfdf3; color:#067647; border-color:#abefc6; font-weight:800; }
.module-card .mode.hybrid { background:#fffaeb; color:#b54708; border-color:#fedf89; }
.module-card .mode.teaser { background:#eff8ff; color:#175cd3; border-color:#b2ddff; }

.sidebar-nav { gap: 11px; }
.sidebar-nav a { color:#344054; background:#ffffff; border-color:#d0d5dd; box-shadow: inset 0 0 0 0 rgba(18,183,106,0); }
.sidebar-nav a.active, .sidebar-nav a:hover { color:#065f46; background:#f0fdf4; border-color:#86efac; box-shadow: inset 4px 0 0 #12b76a; }
.sticky-card { border-color:#d0d5dd; }
.sticky-card .kicker, .sticky-card h3 { color:#155eef; }
.sticky-card p { color:#475467; }

.page-fullversion .sticky-card,
.page-fullversion .sidebar-block,
.page-fullversion .fullversion-sidebar .sticky-card { border:2px solid #86efac; background:linear-gradient(180deg,#f6fff9 0%,#ffffff 100%); box-shadow: 0 16px 34px rgba(18,183,106,.08); }
.page-fullversion .sidebar-nav a { border-color:#b7e7c9; }
.page-fullversion .sidebar-nav a.active,
.page-fullversion .sidebar-nav a:hover { background:#ecfdf3; border-color:#6ce9a6; }
.page-fullversion .sticky-card .kicker { color:#067647; }
.page-fullversion .sticky-card::before { content:"Vollversions-Module"; display:inline-flex; margin-bottom:10px; padding:6px 10px; border-radius:999px; background:#dcfae6; color:#05603a; font-size:12px; font-weight:800; letter-spacing:.02em; }

.hero-form .input,
.hero-form input,
.hero-form select,
.hero-form textarea,
.form .input,
.form input,
.form select,
.form textarea {
  background:#f4fff7;
  border-color:#a6f4c5;
  color:#101828;
}
.hero-form ::placeholder,
.form ::placeholder { color:#6b7280; }
.hero-form .input:focus,
.hero-form input:focus,
.hero-form select:focus,
.hero-form textarea:focus,
.form .input:focus,
.form input:focus,
.form select:focus,
.form textarea:focus {
  outline:none;
  border-color:#12b76a;
  box-shadow:0 0 0 4px rgba(18,183,106,.12);
  background:#ffffff;
}
label, .hero-form label { color:#101828; }
.small-notice, .hero-form .muted, .hero-form p { color:#475467; }

.nav-links a, .lang-switch, .lang-switch a { color:#475467; }
.nav-links a:hover, .nav-links a.active { color:#101828; }
.lang-switch { border-color:#d0d5dd; background:#f8fafc; }
.lang-switch a, .lang-switch span { font-weight:800; }
.lang-switch span { background:linear-gradient(135deg,#155eef,#12b76a); color:#fff; }

.breadcrumbs, .breadcrumbs span, .breadcrumbs a { color:#475467; }
.breadcrumbs a { color:#175cd3; }
.table-compact td, .table-compact th, table td, table th { color:#101828; }
.notice-soft { color:#344054; background:#f9fafb; border:1px solid #d0d5dd; }
.notice { background:#fffaeb; color:#93370d; border-left-color:#f79009; }
.callout { background:#eef8ff; border-color:#b2ddff; }
.callout strong { color:#175cd3; }

@media (max-width: 980px) {
  .logo.brand-logo .brand-logo-img { width: 158px; max-height: 36px; }
  .logo.brand-logo .logo-text span { font-size:13px; }
}
@media (max-width: 720px) {
  .logo.brand-logo .brand-logo-img { width: 146px; max-height: 34px; }
  .logo.brand-logo .logo-text small { font-size:10px; }
}
@media (max-width: 520px) {
  .logo.brand-logo { gap: 8px; }
  .logo.brand-logo .logo-text { display:none; }
}


/* ============================================================
   AIVC Refresh v3 – stronger readability, less internal copy,
   greener sidebar emphasis and one-time attention pulse
   ============================================================ */
.kicker {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: #ecfdf3;
  border: 1px solid #abefc6;
  color: #05603a !important;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .04em;
  line-height: 1.2;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.75);
}
.module-card .eyebrow {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  padding: 6px 10px;
  border-radius: 999px;
  background: #eff8ff;
  border: 1px solid #b2ddff;
  color: #175cd3 !important;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .04em;
  line-height: 1.2;
}
.module-card p,
.data-card p,
.sticky-card p,
.notice-soft,
.callout,
.footer p,
.table-wrap td,
.table-wrap th,
p,
li {
  color: #344054;
}
p.lead,
.hero-form p,
.hero-form .form-note,
.small-notice,
.breadcrumbs,
.breadcrumbs span,
.breadcrumbs a {
  color: #475467;
}
.sidebar-nav a {
  color: #101828 !important;
  font-weight: 600;
  background: #ffffff;
  border-color: #cdd5df;
}
.sidebar-nav a.active,
.sidebar-nav a:hover {
  color: #065f46 !important;
  background: #ecfdf3;
  border-color: #6ce9a6;
  box-shadow: inset 4px 0 0 #12b76a;
}
.module-layout .sticky-card {
  border: 1.5px solid #cfe9d9;
  background: linear-gradient(180deg, #f8fffb 0%, #ffffff 100%);
  animation: aivcSidebarGlow 1.8s ease .35s 1 both;
}
.page-fullversion .sticky-card,
.page-fullversion .fullversion-sidebar .sticky-card {
  border: 2px solid #86efac;
  background: linear-gradient(180deg, #f2fff7 0%, #ffffff 100%);
  box-shadow: 0 18px 40px rgba(18,183,106,.11);
}
.hero-form {
  animation: aivcHeroGlow 1.8s ease .2s 1 both;
}
.hero-form .input,
.hero-form input,
.hero-form select,
.hero-form textarea,
.form .input,
.form input,
.form select,
.form textarea {
  background: #f0fdf4;
  border-color: #86efac;
  color: #101828;
}
.hero-form .input:hover,
.hero-form input:hover,
.hero-form select:hover,
.hero-form textarea:hover {
  border-color: #32d583;
  background: #f7fff9;
}
.hero-form ::placeholder,
.form ::placeholder {
  color: #667085;
}
.section.light .module-card p,
.section.light .data-card p,
.section.light .sticky-card p,
.section.light p,
.section.light li {
  color: #344054;
}
.section.light .module-card .eyebrow {
  color: #175cd3 !important;
}
.section.light .kicker {
  color: #05603a !important;
}
.footer .copyright,
.footer .copyright a,
.footer .copyright a:visited {
  color: inherit;
  text-decoration: none;
}
@keyframes aivcSidebarGlow {
  0%   { box-shadow: 0 0 0 rgba(18,183,106,0); transform: translateY(0); }
  22%  { box-shadow: 0 0 0 6px rgba(18,183,106,.08), 0 18px 40px rgba(18,183,106,.16); transform: translateY(-1px); }
  58%  { box-shadow: 0 0 0 12px rgba(18,183,106,.04), 0 14px 34px rgba(18,183,106,.10); }
  100% { box-shadow: 0 10px 28px rgba(16,24,40,.07); transform: translateY(0); }
}
@keyframes aivcHeroGlow {
  0%   { box-shadow: 0 0 0 rgba(18,183,106,0); }
  28%  { box-shadow: 0 0 0 6px rgba(18,183,106,.08), 0 18px 40px rgba(18,183,106,.14); }
  100% { box-shadow: 0 10px 28px rgba(16,24,40,.07); }
}
@media (prefers-reduced-motion: reduce) {
  .module-layout .sticky-card,
  .hero-form { animation: none !important; }
}


/* ============================================================
   AIVC Refresh v4 – main-site navigation + report-like demo boxes
   ============================================================ */
.nav-main {
  position: sticky;
  top: 0;
  z-index: 60;
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid #eaecf0;
  box-shadow: 0 1px 2px rgba(16,24,40,.04);
}
.nav-main .nav-inner {
  min-height: 74px;
  gap: 14px;
}
.nav-main .brand-logo-only .brand-logo-img {
  width: 170px;
  max-height: 42px;
  object-fit: contain;
}
.nav-main .nav-links {
  gap: 8px;
  color: #475467;
  font-size: 15px;
  flex: 1 1 auto;
  justify-content: center;
}
.nav-main .nav-links a {
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid transparent;
  color: #475467;
  white-space: nowrap;
}
.nav-main .nav-links a:hover {
  background: #f2f4f7;
  color: #101828;
}
.nav-main .nav-links a.active-product {
  background: #ecfdf3;
  border-color: #abefc6;
  color: #067647;
  font-weight: 800;
}
.nav-main .nav-links a.nav-lite {
  background: #12b76a;
  border-color: #12b76a;
  color: #fff !important;
  font-weight: 800;
}
.nav-main .nav-links a.nav-lite:hover {
  background: #079455;
  border-color: #079455;
  color: #fff;
}
.nav-main .nav-actions {
  gap: 8px;
}
.nav-main .lang-switch {
  background: #f8fafc;
  border-color: #d0d5dd;
  color: #475467;
}
.nav-main .lang-switch span {
  background: linear-gradient(135deg, #155eef, #12b76a);
  color: #fff;
}

.subnav {
  position: sticky;
  top: 74px;
  z-index: 55;
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid #eaecf0;
}
.subnav-inner {
  min-height: 56px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: center;
}
.subnav-label {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: #ecfdf3;
  border: 1px solid #abefc6;
  color: #067647;
  font-size: 13px;
  font-weight: 800;
  white-space: nowrap;
}
.subnav-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
.subnav-links a {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid #d0d5dd;
  background: #fff;
  color: #475467;
  font-size: 14px;
  font-weight: 700;
}
.subnav-links a:hover {
  border-color: #86efac;
  background: #f0fdf4;
  color: #067647;
}
.subnav-links a.is-active {
  border-color: #b2ddff;
  background: #eff8ff;
  color: #175cd3;
  box-shadow: inset 0 -2px 0 #175cd3;
}

.page-hero.compact-hero { padding-top: 34px; }
.hero { padding-top: 56px; }

/* Report-like demo boxes */
.demo-report-card {
  background: #fff;
  border: 1px solid #d0d5dd;
  border-radius: 28px;
  padding: 24px;
  box-shadow: 0 18px 40px rgba(16,24,40,.07);
}
.report-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}
.report-chip {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 800;
  border: 1px solid #d0d5dd;
  background: #f8fafc;
  color: #475467;
}
.report-chip.live, .report-chip.ok { background: #ecfdf3; border-color: #abefc6; color: #067647; }
.report-chip.hybrid { background: #fffaeb; border-color: #fedf89; color: #b54708; }
.report-chip.teaser { background: #eef4ff; border-color: #b2ddff; color: #175cd3; }
.report-chip.source { background: #f2f4f7; border-color: #d0d5dd; color: #344054; }
.report-chip.warn { background: #fff7ed; border-color: #fdba74; color: #c2410c; }
.report-chip.fail { background: #fef3f2; border-color: #fda29b; color: #b42318; }
.demo-report-top {
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  gap: 16px;
  align-items: start;
}
.demo-report-title h3 {
  margin: 10px 0 6px;
  font-size: clamp(28px, 4vw, 42px);
  line-height: 1.04;
  letter-spacing: -.03em;
  color: #101828;
}
.demo-report-title p {
  margin: 0;
  color: #475467;
  word-break: break-word;
}
.report-score-badge {
  min-width: 120px;
  min-height: 120px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 2px;
  border-radius: 26px;
  background: linear-gradient(135deg, #155eef, #12b76a);
  color: #fff;
  box-shadow: 0 16px 34px rgba(23,94,211,.18);
  padding: 18px;
  text-align: center;
}
.report-score-badge small {
  font-size: 13px;
  font-weight: 800;
  opacity: .92;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.report-score-badge strong {
  font-size: 42px;
  line-height: .95;
  font-weight: 900;
}
.report-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 14px;
  margin: 18px 0;
}
.report-stat {
  position: relative;
  overflow: hidden;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid #d0d5dd;
  background: #f8fafc;
}
.report-stat::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  height: 4px;
  background: #175cd3;
}
.report-stat.live::before, .report-stat.ok::before { background: #12b76a; }
.report-stat.hybrid::before { background: #f79009; }
.report-stat.warn::before { background: #f79009; }
.report-stat.fail::before { background: #f04438; }
.report-stat strong {
  display: block;
  font-size: 30px;
  line-height: 1;
  color: #101828;
  margin-top: 6px;
}
.report-stat small {
  display: block;
  color: #475467;
  font-size: 13px;
  font-weight: 800;
}
.report-note {
  margin-bottom: 18px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid #d5ebf5;
  background: #eff8ff;
  color: #175cd3;
  font-size: 15px;
  font-weight: 700;
}
.report-content .data-card:first-child,
.report-content > .callout:first-child,
.report-content > .metric-grid:first-child {
  margin-top: 0;
}
.report-content .data-card,
.report-content .callout,
.report-content .table-wrap {
  box-shadow: none;
}

/* result pages closer to the report look */
.page-result .intro-card {
  background: linear-gradient(180deg,#ffffff 0%,#f9fbff 100%);
  border: 1px solid #d0d5dd;
  box-shadow: 0 18px 38px rgba(16,24,40,.06);
}
.page-result .intro-card .lead { color: #475467 !important; }
.page-result .data-card {
  background: #fff;
  border: 1px solid #d0d5dd;
}
.page-result .callout {
  background: #eff8ff;
  border-color: #b2ddff;
}
.page-result .callout strong { color: #175cd3; }
.page-result .metric-card,
.page-result .result-nav-card,
.page-result .demo-summary-box {
  background: #fff;
  border: 1px solid #d0d5dd;
}

/* Make the left menu feel more like a product map */
.module-layout .sticky-card {
  border: 1px solid #b7e7c9;
  background: linear-gradient(180deg,#f8fffb 0%,#ffffff 100%);
  box-shadow: 0 12px 28px rgba(18,183,106,.08);
}
.module-layout .sticky-card .kicker {
  color: #067647 !important;
  background: #dcfae6;
  border-color: #abefc6;
}
.sidebar-nav a {
  background: #fff;
  border-color: #d0d5dd;
  color: #344054 !important;
}
.sidebar-nav a:hover,
.sidebar-nav a.active {
  background: #f0fdf4;
  border-color: #86efac;
  color: #065f46 !important;
  box-shadow: inset 4px 0 0 #12b76a;
}

@media (max-width: 1100px) {
  .nav-main .nav-links { justify-content: flex-start; }
  .report-stat-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 980px) {
  .subnav { top: 72px; }
  .subnav-inner { grid-template-columns: 1fr; padding: 12px 0; }
}
@media (max-width: 720px) {
  .nav-main .nav-inner { align-items: flex-start; flex-direction: column; padding: 14px 0; }
  .nav-main .nav-links { display:none; flex-direction: column; align-items:flex-start; width:100%; }
  .nav-main .nav-links.open { display:flex; }
  .subnav { position: static; }
  .subnav-links { overflow:auto; flex-wrap: nowrap; padding-bottom: 4px; }
  .demo-report-top { grid-template-columns: 1fr; }
  .report-score-badge { min-width: 96px; min-height: 96px; width: 96px; }
  .report-score-badge strong { font-size: 34px; }
  .report-stat-grid { grid-template-columns: 1fr; }
}


/* ============================================================
   AIVC Refresh v5 – top navigation reduced to logo + language
   ============================================================ */
.nav-main.nav-brand-minimal .nav-inner {
  min-height: 76px;
  justify-content: space-between;
}
.nav-main.nav-brand-minimal .brand-logo-only .brand-logo-img {
  width: 178px;
  max-height: 42px;
}
.nav-main.nav-brand-minimal .nav-links,
.nav-main.nav-brand-minimal .nav-toggle {
  display: none !important;
}
.nav-main.nav-brand-minimal .nav-actions {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.nav-main.nav-brand-minimal .nav-actions .lang-switch {
  box-shadow: 0 6px 18px rgba(16,24,40,.06);
}
@media (max-width: 720px) {
  .nav-main.nav-brand-minimal .nav-inner {
    flex-direction: row;
    align-items: center;
    min-height: 68px;
    padding: 10px 0;
  }
  .nav-main.nav-brand-minimal .brand-logo-only .brand-logo-img {
    width: 150px;
    max-height: 34px;
  }
}


/* v6 menu cleanup */
.nav-actions .lang-switch.nav-lang {
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid #cfd7e3;
  background:#f8fafc;
  border-radius:999px;
  padding:8px 12px;
  color:#475467;
  font-weight:800;
}
.nav-actions .lang-switch.nav-lang a,
.nav-actions .lang-switch.nav-lang .current {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:38px;
  min-height:38px;
  padding:0 10px;
  border-radius:999px;
  text-decoration:none;
  font-weight:800;
  transition:all .18s ease;
}
.nav-actions .lang-switch.nav-lang a {
  color:#475467;
  background:transparent;
}
.nav-actions .lang-switch.nav-lang a:hover {
  background:#eaf2ff;
  color:#155eef;
}
.nav-actions .lang-switch.nav-lang .current {
  color:#fff;
  background:linear-gradient(135deg,#155eef,#15b79e);
  box-shadow:0 4px 12px rgba(21,94,239,.16);
}



/* ============================================================
   AIVC v7 – single top navigation with logo + 3 area buttons
   ============================================================ */
.nav-product-top {
  position: sticky;
  top: 0;
  z-index: 60;
  background: #ffffff;
  border-bottom: 1px solid #e4e7ec;
}
.nav-inner.nav-inner-product {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 96px;
  padding: 14px 0;
}
.nav-left-pack {
  display: flex;
  align-items: center;
  gap: 22px;
  min-width: 0;
  flex-wrap: wrap;
}
.site-logo-link {
  flex: 0 0 auto;
}
.site-logo-link .brand-logo-img {
  width: 240px;
  max-width: 100%;
  height: auto;
  max-height: 54px;
  object-fit: contain;
}
.product-top-links {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.product-top-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  border-radius: 999px;
  border: 1px solid #d0d5dd;
  background: #ffffff;
  color: #475467;
  font-weight: 800;
  font-size: 18px;
  text-decoration: none !important;
  transition: all .18s ease;
}
.product-top-link:hover {
  border-color: #98a2b3;
  background: #f8fafc;
  color: #1d2939;
}
.product-top-link.is-active {
  border-color: #86efac;
  background: #ecfdf3;
  color: #067647;
  box-shadow: 0 8px 18px rgba(18,183,106,.10);
}
.nav-inner-product .nav-actions {
  margin-left: auto;
}
/* remove older second row if any remains */
.subnav { display: none !important; }
.breadcrumbs { display: none !important; }
header.page-hero.compact-hero { display: none !important; }
.footer .copyright a,
.footer .copyright a:visited,
.footer .copyright a:hover {
  color: inherit !important;
  text-decoration: none !important;
}
@media (max-width: 1100px) {
  .nav-inner.nav-inner-product {
    align-items: flex-start;
    min-height: 88px;
  }
  .site-logo-link .brand-logo-img {
    width: 210px;
    max-height: 48px;
  }
  .product-top-link {
    min-height: 44px;
    padding: 0 18px;
    font-size: 17px;
  }
}
@media (max-width: 820px) {
  .nav-inner.nav-inner-product {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }
  .nav-left-pack {
    justify-content: space-between;
  }
  .product-top-links {
    width: 100%;
    justify-content: flex-start;
  }
  .nav-inner-product .nav-actions {
    margin-left: 0;
    align-self: flex-end;
  }
}
@media (max-width: 640px) {
  .site-logo-link .brand-logo-img {
    width: 180px;
    max-height: 42px;
  }
  .product-top-links {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
  }
  .product-top-link {
    width: 100%;
    justify-content: center;
    min-height: 46px;
    font-size: 16px;
  }
}
