/**
 * @file base.css
 * Reset, Basis-Typografie, Basis-Elemente und a11y-Helper.
 * Mobile-first: Default-Regeln gelten für kleine Viewports.
 *
 * Die Admin-Toolbar wird von Gin bzw. dem gin_toolbar-Modul gestylt; die
 * Element-Resets hier sind daher global. Sollte etwas in die Toolbar bluten
 * (z. B. Link-Unterstreichung oder SVG-Icons), wieder gezielt eingrenzen.
 */

/* --- Box-Model-Reset --- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  color: var(--color-text);
  background-color: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* --- Medien skalieren mit ihrem Container --- */
:is(img, picture, svg, video) {
  max-width: 100%;
  height: auto;
  display: block;
}

/* --- Überschriften --- */
:is(h1, h2, h3, h4, h5, h6) {
  margin: 0 0 var(--space-sm);
  font-family: var(--font-heading);
  line-height: var(--line-height-heading);
  font-weight: 700;
  text-wrap: balance;
}

h1 { font-size: var(--font-size-h1); }
h2 { font-size: var(--font-size-h2); }
h3 { font-size: var(--font-size-h3); }

:is(p, ul, ol, dl, blockquote, figure, table) {
  margin: 0 0 var(--space-sm);
}

p {
  text-wrap: pretty;
}

/* --- Links --- */
a {
  color: var(--color-link);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

a:hover,
a:focus {
  color: var(--color-link-hover);
}

/* --- Listen --- */
:is(ul, ol) {
  padding-inline-start: 1.25rem;
}

/* --- Sichtbarer, einheitlicher Fokus für Tastaturnutzung --- */
:focus-visible {
  outline: 3px solid var(--color-focus);
  outline-offset: 2px;
  border-radius: 2px;
}

/* Fokus ohne :focus-visible-Unterstützung nicht unterdrücken. */
:focus:not(:focus-visible) {
  outline: none;
}

hr {
  border: 0;
  border-top: 1px solid var(--color-border);
  margin: var(--space-lg) 0;
}

/* ========================================================================
   Buttons – zentrale, wiederverwendbare Komponente
   ========================================================================
   Normalfall: <div class="button"><a href>…</a></div>. Die Optik liegt auf dem
   inneren <a>, das die gesamte Fläche klickbar macht; .button selbst ist nur ein
   schrumpfender Wrapper. Die Klasse darf auch direkt auf <a>/<button> liegen.
   Native Formular-Buttons (input[type=submit]) und die Kontext-/Tab-Links der
   lokalen Aufgaben teilen sich dieselbe Optik.

   Bewusst KEIN bare `button` und KEIN :is() in der Selektorliste: bare `button`
   würde den Hamburger (.menu-toggle) treffen, und :is() würde dessen Spezifität
   an input[type="submit"] anheben. Drupal vergibt an echte Buttons ohnehin die
   Klasse .button. */

.button {
  display: inline-flex;
  max-width: 100%;
}

.button > a,
a.button,
button.button,
input[type="submit"],
input[type="button"],
input[type="reset"],
.block-local-tasks-block .block__content > ul > li > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3xs);
  min-height: 2.75rem;
  padding: var(--space-2xs) var(--space-md);
  font: inherit;
  font-weight: 600;
  line-height: 1.2;
  color: var(--color-white)!important;
  background: var(--color-highlight);
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-sm);
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  transition: background var(--transition-base), border-color var(--transition-base), color var(--transition-base);
}

/* Hover/Fokus: Highlight-(Akzent-)Farbe, dunkler Text für ausreichenden Kontrast. */
.button > a:hover,
.button > a:focus-visible,
a.button:hover,
a.button:focus-visible,
button.button:hover,
button.button:focus-visible,
input[type="submit"]:hover,
input[type="submit"]:focus-visible,
input[type="button"]:hover,
input[type="reset"]:hover,
.block-local-tasks-block .block__content > ul > li > a:hover,
.block-local-tasks-block .block__content > ul > li > a:focus-visible {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-white);
}

/* Akzent-Variante zum expliziten Einsatz der Highlight-Farbe. */
.button--accent > a,
a.button--accent,
.button--accent {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-black);
}

/* ========================================================================
   Lokale Aufgaben / Kontext-Tabs als Button-Reihe
   ======================================================================== */
.block-local-tasks-block .block__content > ul {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2xs);
  list-style: none;
  margin: 0 0 var(--space-md);
  padding: 0;
}

.block-local-tasks-block .block__content > ul > li {
  margin: 0;
}

/* Aktiver Tab (aktuelle Seite): dauerhaft in Highlight-Farbe. */
.block-local-tasks-block .block__content > ul > li > a.is-active,
.block-local-tasks-block .block__content > ul > li > a[aria-current="page"] {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-black);
}

/* ========================================================================
   Accessibility-Helper
   ======================================================================== */

/* Visuell verstecken, aber für Screenreader verfügbar halten. */
.visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

/* Bei Fokus wieder sichtbar machen (z. B. Skip-Link). */
.visually-hidden.focusable:focus,
.visually-hidden.focusable:focus-within {
  position: fixed !important;
  top: var(--space-2xs);
  left: var(--space-2xs);
  z-index: 1000;
  width: auto;
  height: auto;
  padding: var(--space-2xs) var(--space-sm);
  margin: 0;
  overflow: visible;
  clip: auto;
  clip-path: none;
  white-space: normal;
  background: var(--color-bg);
  color: var(--color-text);
  box-shadow: var(--shadow-md);
  border-radius: var(--radius-sm);
}

/* ========================================================================
   Motion-Präferenz respektieren
   ======================================================================== */

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

body .toolbar-fixed .toolbar-oriented .toolbar-bar {
  top: 0 !important;
  position:relative !important;
}


