:root{
    --text:#0f172a; --muted:#475569; --bg:#ffffff;
    --card:#f8fafc; --line:#e2e8f0;
    --brand:#6d28d9; --brand-weak:#ede9fe; --focus:#7c3aed;
    --radius:14px; --maxw:920px;
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0;background:var(--bg);color:var(--text)}
  body{font-family:"Satoshi","Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif; line-height:1.6}
  a{color:var(--brand);text-decoration:none}
  a:hover{text-decoration:underline}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:40px 20px}
  header{margin-bottom:28px}
  h1{font-size:clamp(28px,4vw,40px);line-height:1.15;margin:0 0 8px 0}
  .meta{color:var(--muted);font-size:14px}
  .badge{display:inline-block;background:var(--brand-weak);color:var(--brand);border:1px solid var(--line);padding:6px 10px;border-radius:999px;font-weight:600;margin-top:8px}
  .toolbar{display:flex;gap:10px;margin:18px 0 28px 0;flex-wrap:wrap}
  .btn{appearance:none;border:1px solid var(--line);background:var(--brand-weak);color:var(--brand);
       padding:10px 14px;border-radius:10px;font-weight:600;cursor:pointer}
  .btn:hover{background:#efeafe}
  .card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
  .toc h2{font-size:16px;margin:0 0 10px 0;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
  .toc ol{margin:0;padding-left:18px}
  .toc li{margin:6px 0}
  main h2{font-size:22px;margin:30px 0 8px 0;padding-top:12px;border-top:1px solid var(--line)}
  main h3{font-size:18px;margin:18px 0 6px 0}
  p,li{font-size:16px;color:var(--text)}
  .note{background:#fff;border:1px dashed var(--line);padding:14px;border-radius:10px;color:var(--muted)}
  .block{margin:14px 0}
  footer{margin-top:40px;padding-top:20px;border-top:1px solid var(--line);color:var(--muted);font-size:14px}
  html{scroll-behavior:smooth}
  @media print{
    .toolbar,.toc{display:none!important}
    header{margin-bottom:0}
    main h2{break-inside:avoid}
    a[href]:after{content:" (" attr(href) ")";font-size:12px;color:#555}
    body{font-size:12pt}
  }
  @media (min-width:900px){
    .grid{display:grid;grid-template-columns: 280px 1fr;gap:24px;align-items:start}
    .toc{position:sticky;top:20px}
  }

.header-flex{
display:flex;
flex-direction:column;
align-items:center;
text-align:center;
}
.brandbar{
display:flex;
justify-content:center;
width:100%;
}
.brandlogo{
width: 250px !important;
height: auto !important;
display: block;
margin: 6px auto 12px;
}
  .site-footer{display:flex;justify-content:center;align-items:center;text-align:center}
  /* Print-optimized layout */
  @page { size: A4; margin: 12mm; }
  @media print{
    body{font-size:10pt; line-height:1.35}
    .wrap{padding:0}
    h1{font-size:18pt;margin-bottom:6px}
    .meta,.badge{font-size:9pt}
    main h2{font-size:12pt;margin:16px 0 6px 0;padding-top:6px;border-top:1px solid #ddd}
    main h3{font-size:11pt;margin:10px 0 4px 0}
    p,li{font-size:10pt;margin:4px 0}
    .note{font-size:9.5pt;padding:8px}
    .card{padding:10px}
    .grid{display:block}
    footer{border-top:1px solid #ddd;margin-top:10px;padding-top:6px}
  }

/* Language switcher */
.lang-switch{margin-left:auto;display:flex;align-items:center;gap:8px}
.lang-switch label{font-size:13px;color:var(--muted)}
.lang-switch select{
overflow:visible;
display:inline-block;
line-height:1.3;
appearance:none;-webkit-appearance:none;-moz-appearance:none;
border:1px solid var(--line);background:#fff;
padding:8px 34px 8px 10px;border-radius:10px;font-weight:600;cursor:pointer;
}
.lang-switch .select-wrap{
align-items:center;
min-height:40px;position:relative}
.lang-switch .select-wrap:after{
content:"";position:absolute;right:10px;top:50%;transform:translateY(-50%);
width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--muted);
pointer-events:none;
}
.globe{display:inline-block;width:18px;height:18px;border-radius:50%;border:2px solid var(--muted);position:relative;margin-right:6px;opacity:.8}
.globe:before,.globe:after{content:"";position:absolute;background:var(--muted);opacity:.6}
.globe:before{left:50%;top:2px;bottom:2px;width:2px;transform:translateX(-50%)}
.globe:after{left:3px;right:3px;top:50%;height:2px;transform:translateY(-50%)}
@media print{ .lang-switch{display:none!important} }


/* === Harmonized Toolbar Controls (Buttons + Language Select) === */
:root{
--bc-accent:#6b2cff;
--bc-accent-ink:#4c1db8;
--bc-pill-bg: rgba(107,44,255,0.08);
--bc-pill-bg-hover: rgba(107,44,255,0.12);
--bc-border:#e6e6ef;
--bc-ink:#1d1d24;
--bc-muted:#6b7280;
--bc-radius:16px;
--bc-shadow: 0 1px 2px rgba(0,0,0,.06), 0 4px 12px rgba(0,0,0,.06);
--bc-shadow-hover: 0 2px 6px rgba(0,0,0,.08), 0 8px 18px rgba(0,0,0,.10);
}

/* Ensure toolbar inherits global font (Satoshi on the page) */
.toolbar{ font: inherit; }

/* Base pill look shared by buttons and selects */
.toolbar .pill,
.lang-switch .select-wrap,
.toolbar .btn,
.toolbar a.btn,
.toolbar button {
display:inline-flex; align-items:center; justify-content:center;
gap:.6rem; padding:.75rem 1.1rem;
border-radius: var(--bc-radius);
border:1px solid var(--bc-border);
background: var(--bc-pill-bg);
box-shadow: var(--bc-shadow);
color: var(--bc-accent);
font-weight:700; font-size: 15px; line-height:1;
text-decoration:none; cursor:pointer; transition: all .2s ease;
-webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
}

/* Hover / focus states */
.toolbar .pill:hover,
.lang-switch .select-wrap:hover,
.toolbar .btn:hover,
.toolbar a.btn:hover,
.toolbar button:hover {
background: var(--bc-pill-bg-hover);
transform: translateY(-1px);
box-shadow: var(--bc-shadow-hover);
}

/* Pressed */
.toolbar .pill:active,
.lang-switch .select-wrap:active,
.toolbar .btn:active,
.toolbar a.btn:active,
.toolbar button:active {
transform: translateY(0);
box-shadow: var(--bc-shadow);
}

/* Ensure "Kontakt" und "Drucken / PDF" keep their link styles but with accent */
.toolbar a, .toolbar button { color: var(--bc-accent); }

/* --- Language select styled as a pill button --- */
.lang-switch{ margin-left:auto; display:flex; align-items:center; gap:10px; }
.lang-switch label{ font-size:15px; color: var(--bc-muted); font-weight:600; }
.lang-switch .globe{ width:20px; height:20px; border-color: var(--bc-muted); opacity:.9; }
.lang-switch .select-wrap{
align-items:center;
min-height:40px; position:relative; }
.lang-switch select{
overflow:visible;
display:inline-block;
appearance:none; -webkit-appearance:none; -moz-appearance:none;
font: inherit; font-weight:700; font-size:15px; line-height:1.3;
padding:.75rem 2.2rem .75rem 1rem; border-radius: var(--bc-radius);
border:1px solid var(--bc-border); background: transparent;
color: var(--bc-accent); cursor:pointer;
outline:none; background-clip:padding-box;
}
.lang-switch .select-wrap:after{
content:""; position:absolute; right:12px; top:50%; transform:translateY(-50%);
width:0; height:0; border-left:6px solid transparent; border-right:6px solid transparent;
border-top:7px solid var(--bc-accent-ink); pointer-events:none;
}

/* Make the select wrap look like the buttons (same bg + shadow) */
.lang-switch .select-wrap{
align-items:center;
min-height:40px;
background: var(--bc-pill-bg);
box-shadow: var(--bc-shadow);
border-radius: var(--bc-radius);
border:1px solid var(--bc-border);
}

/* Hover matches buttons */
.lang-switch .select-wrap:hover{
background: var(--bc-pill-bg-hover);
}

/* Print: hide toolbar */
@media print{
.toolbar, .lang-switch{ display:none !important; }
}

/* Force text justification for better readability */
main, .content, .cgu-body, article, section, p {
text-align: justify;
text-justify: inter-word;
}

/* Ensure TOC uses Satoshi font */
.toc, .toc li, .toc a, .toc span, .toc::marker {
font-family: 'Satoshi', sans-serif !important;
}

/* Toolbar alignment: three controls in one row */
.toolbar{ display:flex; gap:16px; align-items:center; flex-wrap:wrap; }
.lang-switch{ margin-left:0 !important; display:flex; align-items:center; gap:10px; }
/* Keep select heights matching buttons */
.lang-switch .select-wrap,
.lang-switch select{
overflow:visible;
display:inline-block;
line-height:1.3;
height:auto;
}

/* === Make language selector match button size and remove inner frame === */
.lang-switch .select-wrap{
min-height:40px;
display:inline-flex; align-items:center; justify-content:center;
padding:.75rem 1.1rem;
border-radius: var(--bc-radius);
border:1px solid var(--bc-border);
background: var(--bc-pill-bg);
box-shadow: var(--bc-shadow);
min-width: 140px;
}
.lang-switch .select-wrap:hover{
background: var(--bc-pill-bg-hover);
box-shadow: var(--bc-shadow-hover);
}
.lang-switch select{
overflow:visible;
display:inline-block;
flex:1 1 auto;
width:100%;
background: transparent;
border: 0;
padding: 0;
margin: 0;
font: inherit; font-weight:700; font-size:15px; line-height:1.3;
color: var(--bc-accent);
outline: none;
}
.lang-switch .select-wrap:after{ right: 10px; }

/* Center language text inside the button */
.lang-switch select{
overflow:visible;
display:inline-block;
line-height:1.3;
text-align: center;
padding: 0 .8rem;
}

.nowrap{ white-space: nowrap; }
