/* ============================================================
   Loma Pflege · v05 App-Shell — geteilte Komponenten-Schicht
   Single Source of Truth für alle navigierbaren v05-Screens.
   Die Shell-Regeln (Reset, Shell, Liquid-Glass Header+Footer,
   Hero, Status-Listen, Tabbar, Icons, Focus) sind 1:1 aus
   home.html extrahiert — Homescreen rendert dadurch unverändert.
   Darunter: wiederverwendbare Bausteine (Buttons, Formularfelder,
   Step-Indicator, Ampel, Summary-Rows) für Antrag/Akut/Tagescheck/
   Vorgang/Profil. Nur --loma-*-Tokens; Roh-Werte nur dort, wo schon
   home.html sie als bewusste Ausnahme führt (Sonnen-Gradient).
   ============================================================ */

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  background: var(--loma-surface-warm);
  font-family: var(--loma-font-product);
  color: var(--loma-text-primary);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  display: grid;
  place-items: center;
}

/* HIG: Tap-Ziel für 65+ auf 48px (Apple-Minimum ist 44, Senioren brauchen mehr) */
:root {
  --loma-touch-target: 48px;
  --loma-shell-header-reserve: calc(var(--loma-shell-header-height) + var(--loma-space-2) + var(--loma-space-1) + env(safe-area-inset-top) + var(--loma-space-3));
  --loma-glass-header-bg: rgba(250, 248, 244, 0.70);
  --loma-glass-nav-bg: rgba(250, 248, 244, 0.50);
  --loma-glass-nav-bg-active: rgba(250, 248, 244, 0.82);
  --loma-glass-tabbar-bg: rgba(250, 248, 244, 0.08);
  --loma-tabbar-side-inset: clamp(0.75rem, 4vw, 1.125rem);
  --loma-tabbar-bottom-gap: 0.75rem;
  --loma-tabbar-active-bg: rgba(255, 255, 255, 0.28);
  --loma-tabbar-active-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92), inset 0 0 0 1px rgba(255, 255, 255, 0.55), inset 0 -10px 18px rgba(27, 26, 24, 0.05), 0 7px 18px rgba(27, 26, 24, 0.14);
  --loma-tabbar-press-bg: rgba(255, 255, 255, 0.46);
}

/* ---- App-Shell (Telefon-Fläche) ---- */
.shell {
  position: relative;
  isolation: isolate;
  width: 100%;
  height: 100dvh;
  min-height: 0;
  background: var(--loma-surface-page);
  overflow: hidden;
}
.shell::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: var(--loma-surface-page);
}
@media (min-width: 480px) {
  .shell {
    max-width: 390px;
    height: min(100dvh, 880px);
    margin-inline: auto;
    border-radius: 28px;
    box-shadow: var(--loma-elevation-3);
  }
}

/* ---- Header (Overlay) — Liquid Glass, Content scrollt darunter ---- */
.shell-header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--loma-z-header);
  view-transition-name: --vt-header;
  /* Liquid Glass (iOS-26): transluzenter, bewusst leicht heller als die Page-Fläche.
     Filterwerte bleiben literal, weil Safari var() in backdrop-filter unzuverlässig
     behandelt. */
  background: var(--loma-glass-header-bg);
  -webkit-backdrop-filter: blur(20px) saturate(135%) brightness(1.02);
  backdrop-filter: blur(20px) saturate(135%) brightness(1.02);
  /* Glaskanten: feiner heller Specular-Oberrand + Hairline-Trennkante zum Inhalt +
     weicher Schlagschatten nach unten — die Leiste schwebt über dem Scroll-Inhalt. */
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.6),
    inset 0 -1px 0 rgba(27, 26, 24, 0.06),
    0 6px 20px rgba(27, 26, 24, 0.06);
  padding: var(--loma-space-2) var(--loma-space-4) var(--loma-space-1);
  padding-top: calc(var(--loma-space-2) + env(safe-area-inset-top));
}
.shell-header__bar {
  display: flex;
  align-items: center;
  gap: var(--loma-space-2);
  min-height: var(--loma-shell-header-height);
}

/* Brand-Variante (Homescreen) */
.brand {
  display: flex;
  align-items: center;
  gap: var(--loma-space-2);
  flex: 1;
  min-width: 0;
  min-height: var(--loma-touch-target);
  text-decoration: none;
  color: inherit;
}
.brand__mark {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: var(--loma-radius-icon);
  background: var(--loma-brand-cream);
  color: var(--loma-brand-sage-dark);
  overflow: hidden;
  flex: none;
}
.brand__name {
  font-family: var(--loma-font-brand);
  font-size: var(--loma-text-lg);
  font-weight: 600;
  letter-spacing: -0.01em;
}

/* Titel-Variante (Tab-Roots ausser Home) + Back-Variante (Sub-Screens) */
.shell-header__title {
  flex: 1;
  min-width: 0;
  margin: 0;
  font-family: var(--loma-font-brand);
  font-size: var(--loma-text-lg);
  font-weight: 600;
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.header-back {
  display: inline-grid;
  place-items: center;
  width: var(--loma-touch-target);
  height: var(--loma-touch-target);
  margin-left: calc(-1 * var(--loma-space-2));
  flex: none;
  border: 0;
  background: transparent;
  border-radius: var(--loma-radius-round);
  color: var(--loma-text-primary);
  text-decoration: none;
  cursor: pointer;
}
.header-back:active { background: var(--loma-state-pressed); }
/* Optionaler Header-Trailing-Slot (z.B. Hilfe/112) */
.header-trailing {
  display: inline-grid;
  place-items: center;
  min-width: var(--loma-touch-target);
  min-height: var(--loma-touch-target);
  flex: none;
  border: 0;
  background: transparent;
  border-radius: var(--loma-radius-round);
  color: var(--loma-text-secondary);
  text-decoration: none;
  cursor: pointer;
  font-family: var(--loma-font-product);
  font-size: var(--loma-text-sm);
  font-weight: 600;
}
.header-trailing:active { background: var(--loma-state-pressed); }

/* ---- Schwebender Zurück-Button (Flows ohne sticky Header) ----
   Runder Liquid-Glass-Kreis oben links, schwebt über dem Flow-Inhalt.
   Ersetzt in linearen Flows den .shell-header (Back + Titel). Gleiche
   Glas-Sprache wie Header/Tabbar: blur + dezente Translucency + feine
   weisse Specular-Oberkante + zarter Rand — iOS-Stil, nicht glossy. */
.nav-back {
  position: absolute;
  top: calc(env(safe-area-inset-top) + var(--loma-space-3));
  left: var(--loma-space-3);
  z-index: var(--loma-z-header);
  display: inline-grid;
  place-items: center;
  width: var(--loma-touch-target);
  height: var(--loma-touch-target);
  border: 0;
  border-radius: var(--loma-radius-round);
  background: var(--loma-glass-nav-bg);
  -webkit-backdrop-filter: blur(30px) saturate(180%) brightness(1.04);
  backdrop-filter: blur(30px) saturate(180%) brightness(1.04);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.75),
    inset 0 0 0 1px rgba(27, 26, 24, 0.05),
    var(--loma-elevation-2);
  color: var(--loma-text-primary);
  text-decoration: none;
  cursor: pointer;
  transition: transform var(--loma-duration-tap) var(--loma-ease-out),
              background var(--loma-duration-tap) var(--loma-ease-out);
}
.nav-back:active { transform: scale(0.92); background: var(--loma-glass-nav-bg-active); }
.nav-back .icon { width: var(--loma-icon-md); height: var(--loma-icon-md); }

/* Top-Scrim für Flow-Screens: Inhalt blendet unter dem schwebenden Zurück-Button aus. */
.shell:has(.nav-back)::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: calc(var(--loma-z-header) - 1);
  /* Gradient spannt vom Bildschirm-Anfang (top:0): solid durch das Button-Band,
     dann ein langer, sanfter Fade über eine space-5-Zone bis genau zum Content-Start
     (= nav-back-Reserve unten). So bleibt der Ruhe-Content scharf, der Fade wirkt
     erst, wenn Inhalt beim Scrollen in die Zone läuft. */
  height: calc(env(safe-area-inset-top) + var(--loma-space-3)
               + var(--loma-touch-target) + var(--loma-space-5));
  pointer-events: none;
  background: linear-gradient(
    to bottom,
    rgba(246, 244, 241, 1) 0,
    rgba(246, 244, 241, 1) calc(env(safe-area-inset-top) + var(--loma-space-3)
                                  + var(--loma-touch-target)),
    rgba(246, 244, 241, 0.85) calc(env(safe-area-inset-top) + var(--loma-space-3)
                                     + var(--loma-touch-target) + var(--loma-space-2)),
    rgba(246, 244, 241, 0.45) calc(env(safe-area-inset-top) + var(--loma-space-3)
                                     + var(--loma-touch-target) + var(--loma-space-3)),
    rgba(246, 244, 241, 0) 100%
  );
}

/* ---- Scroll-Bereich ---- */
.shell-content {
  position: absolute;
  inset: 0;
  z-index: 1;
  height: 100%;
  min-height: 0;
  overflow-y: scroll;
  overscroll-behavior: contain;
  touch-action: pan-y;
  -webkit-overflow-scrolling: touch;
  background: transparent;
  padding: var(--loma-space-3) 1.25rem
           calc(var(--loma-shell-tabbar-height) + var(--loma-space-6) + env(safe-area-inset-bottom));
  scroll-padding-top: var(--loma-shell-header-reserve);
  scroll-padding-bottom: calc(var(--loma-shell-tabbar-height) + var(--loma-space-6) + env(safe-area-inset-bottom));
  display: flex;
  flex-direction: column;
  gap: var(--loma-space-4);
}
.shell-content > * { flex: none; }
.shell:has(> .shell-header) > .shell-content {
  padding-top: var(--loma-shell-header-reserve);
}
.shell-content--health {
  padding-bottom: calc(var(--loma-shell-tabbar-height) + var(--loma-space-7) + env(safe-area-inset-bottom));
  scroll-padding-bottom: calc(var(--loma-shell-tabbar-height) + var(--loma-space-7) + env(safe-area-inset-bottom));
}
/* Sub-Screens ohne Tabbar: Bottom-Padding nur Safe-Area + Luft.
   Top-Safe-Area-Reserve fängt chromlose Flows (z.B. bestaetigung: kein Header,
   kein .nav-back) ab; Header-/nav-back-Regeln überschreiben per höherer
   Spezifität, wo Chrome vorhanden ist. */
.shell-content--flow {
  padding-top: calc(env(safe-area-inset-top) + var(--loma-space-3));
  padding-bottom: calc(var(--loma-space-5) + env(safe-area-inset-bottom));
  scroll-padding-bottom: calc(var(--loma-space-5) + env(safe-area-inset-bottom));
}
/* Flow mit schwebendem .nav-back (kein sticky Header): Inhalt startet unter
   Notch + Button. Greift nur, wenn die Shell tatsächlich einen .nav-back trägt —
   Screens mit klassischem .shell-header bleiben dadurch unberührt. */
.shell:has(.nav-back) .shell-content {
  padding-top: calc(env(safe-area-inset-top) + var(--loma-space-3)
                    + var(--loma-touch-target) + var(--loma-space-5));
}
/* Zentrierter Inhalt (Erfolg/Leer-Zustände) */
.shell-content--center { justify-content: center; }

/* ---- Grosse Seiten-Überschrift (iOS Large Title, im Scroll) ---- */
.page-head { margin: var(--loma-space-1) 0 var(--loma-space-1); }
.page-head__title {
  margin: 0;
  font-family: var(--loma-font-brand);
  font-size: var(--loma-text-xl);
  font-weight: 700;
  line-height: var(--loma-line-heading);
  letter-spacing: -0.01em;
}
.page-head__sub {
  margin: var(--loma-space-2) 0 0;
  max-width: 32ch;
  font-size: var(--loma-text-md);
  line-height: var(--loma-line-body);
  color: var(--loma-text-secondary);
}

/* ---- HERO — Salbeigrün, dominantes Element ---- */
.hero {
  position: relative;
  overflow: hidden;
  background: var(--loma-brand-sage-dark);
  color: var(--loma-text-on-ink);
  border-radius: var(--loma-radius-card-lg);
  box-shadow: var(--loma-elevation-3);
  padding: var(--loma-space-4);
}
.hero__sun {
  position: absolute;
  /* Item 1 (v2.1): höher + kleiner gerückt, damit Sonne UND ihre Ringe als
     reine Ecken-Deko oben rechts sitzen und die Reward-/Bar-Zone darunter nicht
     mehr optisch kreuzen (Bar-Track bleibt translucent für Cream-Fill ≥3:1). */
  right: -58px;
  top: -82px;
  width: 172px;
  height: 172px;
  border-radius: var(--loma-radius-round);
  background: radial-gradient(circle at 38% 38%,
              #e7795f 0%,
              var(--loma-brand-terracotta) 58%,
              #c9512f 100%);
  box-shadow: 0 0 0 12px rgba(223, 101, 71, 0.12),
              0 0 0 26px rgba(223, 101, 71, 0.05);
  z-index: 0;
  pointer-events: none;
}
.hero__hill-back {
  position: absolute;
  left: -60px;
  bottom: -96px;
  width: 300px;
  height: 170px;
  border-radius: 50% 50% 0 0;
  background: var(--loma-brand-sage);
  opacity: 0.30;
  z-index: 0;
  pointer-events: none;
}
.hero__hill-front {
  position: absolute;
  right: -70px;
  bottom: -104px;
  width: 280px;
  height: 168px;
  border-radius: 50% 50% 0 0;
  background: var(--loma-brand-sage);
  opacity: 0.20;
  z-index: 0;
  pointer-events: none;
}
/* Lead — motivierende Kopfzeile; bewusst KEIN Display-Maß, denn der Zahlen-Held
   (131 €) ist die eine Display-Aussage des Screens (Kompositions-Standard Nr. 3). */
.hero__lead {
  position: relative;
  z-index: 1;
  margin: 0 0 var(--loma-space-3);
  max-width: 14ch;
  font-family: var(--loma-font-brand);
  font-size: var(--loma-text-xl);
  font-weight: 700;
  line-height: var(--loma-line-heading);
  letter-spacing: -0.01em;
  text-wrap: balance;
}

/* Display-Hero — Frage/Aussage als Held (Tab-Root-Landings, z.B. Tagescheck) */
.hero__display {
  position: relative;
  z-index: 1;
  margin: 0 0 var(--loma-space-3);
  max-width: 14ch;
  font-family: var(--loma-font-brand);
  font-size: var(--loma-text-display);
  font-weight: 700;
  line-height: var(--loma-line-heading);
  letter-spacing: -0.01em;
  text-wrap: balance;
}
.hero__sub {
  position: relative;
  z-index: 1;
  margin: 0 0 var(--loma-space-4);
  max-width: 28ch;
  font-size: var(--loma-text-md);
  line-height: var(--loma-line-body);
  color: var(--loma-text-on-ink);
  opacity: 0.94;
}

/* Belohnungs-Block (m09-Iteration, Johans 90%-Bar): Entlastungsbetrag als
   Zahlen-Held + „fast geschafft"-Fortschritt — koppelt die Belohnung (131 €)
   sichtbar an die eine offene Aktion (Unterschrift). */
.hero__reward { position: relative; z-index: 1; max-width: 18rem; margin: 0 0 var(--loma-space-4); }
.hero__amount {
  margin: 0;
  display: flex;
  align-items: baseline;
  gap: var(--loma-space-2);
  color: var(--loma-text-on-ink);
}
.hero__amount b {
  font-family: var(--loma-font-brand);
  font-size: var(--loma-text-value-lg);
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
  font-feature-settings: var(--loma-numeric-features);
}
.hero__amount-unit { font-size: var(--loma-text-md); font-weight: 600; opacity: 0.82; }
.hero__bar {
  margin-top: var(--loma-space-3);
  height: 8px;
  border-radius: var(--loma-radius-round);
  background: rgba(255, 255, 255, 0.24); /* hellerer Track macht den 90%-Füllstand als diskreten Balken lesbar (Fill ≥3:1 vs Track) */
  overflow: hidden;
}
.hero__bar-fill {
  display: block;
  height: 100%;
  width: calc(max(var(--p, 0), 0.08) * 100%);
  border-radius: inherit;
  background: var(--loma-brand-cream);
  transform-origin: left;
  animation: hero-bar-fill var(--loma-duration-slow) var(--loma-ease-out) both;
}
@keyframes hero-bar-fill { from { transform: scaleX(0); } }
.hero__bar-label {
  margin: var(--loma-space-2) 0 0;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--loma-text-on-ink);
  opacity: 0.88;
  font-variant-numeric: tabular-nums;
}
.hero__note {
  position: relative;
  z-index: 1;
  margin: var(--loma-space-2) 0 0;
  font-size: 0.8125rem;
  line-height: 1.4;
  color: var(--loma-text-on-ink-muted);
}
.hero__cta { position: relative; z-index: 1; }

/* ---- Home-Status: drei Säulen + vertikale Vorgangsliste ---- */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--loma-space-2);
}
.stat-tile {
  min-width: 0;
  min-height: 116px;
  padding: var(--loma-space-3);
  border-radius: var(--loma-radius-card);
  background: var(--loma-surface-card);
  box-shadow: var(--loma-elevation-1);
  display: flex;
  flex-direction: column;
  gap: var(--loma-space-1);
}
.stat-tile__label {
  margin: 0;
  font-size: var(--loma-text-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--loma-text-muted);
}
.stat-tile__main {
  margin: 0;
  font-size: var(--loma-text-md);
  font-weight: 800;
  line-height: 1.16;
  color: var(--loma-text-primary);
}
.stat-tile__sub {
  margin: auto 0 0;
  font-size: var(--loma-text-xs);
  font-weight: 600;
  line-height: 1.35;
  color: var(--loma-text-secondary);
}
.stat-tile--action { background: var(--loma-status-warn-soft); }
.stat-tile--action .stat-tile__main,
.stat-tile--action .stat-tile__sub { color: var(--loma-status-warn-text); }
.stat-tile--ok { background: var(--loma-status-ok-soft); }
.stat-tile--ok .stat-tile__main,
.stat-tile--ok .stat-tile__sub { color: var(--loma-status-ok-text); }
.stat-tile--muted { background: var(--loma-surface-card); }
.stat-tile--muted .stat-tile__sub { color: var(--loma-text-muted); }
.row-v2__status--action { background: var(--loma-status-warn-soft); color: var(--loma-status-warn-text); }
.row-v2__status--ok { background: var(--loma-status-ok-soft); color: var(--loma-status-ok-text); }
.row-v2__meta {
  display: inline-flex;
  align-items: center;
  min-height: 1.5rem;
  padding: 0 var(--loma-space-2);
  border-radius: var(--loma-radius-badge);
  background: var(--loma-status-warn-soft);
  color: var(--loma-status-warn-text);
  font-size: var(--loma-text-xs);
  font-weight: 700;
  white-space: nowrap;
}
@media (max-width: 360px) {
  .stat-grid { grid-template-columns: 1fr; }
  .stat-tile { min-height: auto; }
}

/* ---- Buttons ---- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--loma-space-2);
  min-width: 0;
  min-height: var(--loma-touch-target);
  padding: var(--loma-space-2) var(--loma-space-4);
  border: 0;
  border-radius: var(--loma-radius-button);
  font-family: var(--loma-font-product);
  font-size: var(--loma-text-md);
  font-weight: 600;
  line-height: 1.25;
  text-decoration: none;
  overflow-wrap: anywhere;
  cursor: pointer;
  transition: background var(--loma-duration-tap) var(--loma-ease-out),
              transform var(--loma-duration-tap) var(--loma-ease-out);
}
.btn:active { transform: scale(0.99); }
.btn--block { width: 100%; }
/* Heller CTA mit warmem Pfeil — der Homescreen-Hero-CTA (Kontrast statt Größe) */
.btn--light {
  background: var(--loma-surface-card);
  color: var(--loma-text-primary);
  box-shadow: var(--loma-elevation-2);
}
.btn--light:hover { background: var(--loma-surface-warm); }
.btn--light:active { background: var(--loma-surface-sunken); }
.btn--light .arrow { color: var(--loma-action-warm); }
/* Warmer Primär-CTA (Terracotta, weisser Text) — der EINE Brennpunkt pro Screen */
.btn--warm {
  background: var(--loma-action-warm);
  color: var(--loma-action-warm-text);
  box-shadow: var(--loma-elevation-2);
}
.btn--warm:hover { background: var(--loma-action-warm-hover); }
.btn--warm:active { background: var(--loma-action-warm-hover); }
.btn--warm .arrow { color: var(--loma-action-warm-text); }
/* Ink-Primär (neutral, kein warmer Moment) */
.btn--ink {
  background: var(--loma-action-primary);
  color: var(--loma-action-primary-text);
  box-shadow: var(--loma-elevation-2);
}
.btn--ink:hover { background: var(--loma-action-primary-hover); }
/* Sekundär (weisser Knopf mit Hairline) */
.btn--secondary {
  background: var(--loma-surface-card);
  color: var(--loma-text-primary);
  box-shadow: inset 0 0 0 var(--loma-hairline) var(--loma-border-subtle);
}
.btn--secondary:active { background: var(--loma-surface-warm); }
/* Geister-/Text-Button (tertiär) */
.btn--ghost {
  background: transparent;
  color: var(--loma-text-secondary);
}
.btn--ghost:active { background: var(--loma-state-pressed); }
.btn[aria-disabled="true"] {
  background: var(--loma-action-disabled-bg);
  color: var(--loma-action-disabled-text);
  box-shadow: none;
  pointer-events: none;
}

/* Aktionsleiste am unteren Rand eines Flow-Screens. Standard bleibt in-flow;
   lineare Tagescheck-Schritte nutzen zusätzlich .action-bar--sticky, damit der
   primäre CTA im Daumenbereich bleibt und nicht unterhalb des Folds landet. */
.action-bar {
  margin: auto calc(-1 * 1.25rem) 0;
  padding: var(--loma-space-4) 1.25rem calc(var(--loma-space-4) + env(safe-area-inset-bottom));
  display: flex;
  flex-direction: column;
  gap: var(--loma-space-2);
}
.action-bar--sticky {
  position: sticky;
  bottom: 0;
  z-index: calc(var(--loma-z-tabbar) - 2);
  margin-top: auto;
  padding-top: var(--loma-space-3);
  background: linear-gradient(
    to top,
    rgba(246, 244, 241, 1) 0,
    rgba(246, 244, 241, 0.98) calc(100% - var(--loma-space-4)),
    rgba(246, 244, 241, 0) 100%
  );
}
.shell-content--flow:has(.action-bar--sticky) {
  padding-bottom: 0;
  scroll-padding-bottom: calc(var(--loma-touch-target) + var(--loma-space-6) + env(safe-area-inset-bottom));
}

/* ---- Abschnitts-Eyebrow ---- */
.section-eyebrow {
  margin: 0 0 var(--loma-space-2);
  padding: 0 var(--loma-space-1);
  font-size: var(--loma-text-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--loma-text-muted);
}

/* ---- Karten + status-geführte Listenzeilen ---- */
.card-wash {
  background: var(--loma-surface-card);
  border-radius: var(--loma-radius-card);
  box-shadow: var(--loma-elevation-1);
  padding: var(--loma-space-1) var(--loma-space-4);
}
/* Voll-Karte (mit eigenem Innenabstand, für Detail-/Inhaltskarten) */
.card {
  background: var(--loma-surface-card);
  border-radius: var(--loma-radius-card);
  box-shadow: var(--loma-elevation-1);
  padding: var(--loma-space-4);
}
.row-v2 {
  display: flex;
  align-items: flex-start;
  gap: var(--loma-space-3);
  min-height: var(--loma-touch-target);
  padding: var(--loma-density-card) 0;
  text-decoration: none;
  color: inherit;
}
.row-v2 + .row-v2 { border-top: var(--loma-hairline) solid var(--loma-border-soft); }
.row-v2:active { background: var(--loma-state-pressed); }
.row-v2__body { flex: 1; min-width: 0; }
.row-v2__title { margin: 0; font-size: var(--loma-text-md); font-weight: 600; line-height: 1.3; }
.row-v2__caption { margin: 3px 0 0; font-size: var(--loma-text-sm); color: var(--loma-text-secondary); line-height: 1.4; }
.row-v2__caption b { font-weight: 600; color: var(--loma-text-primary); }
.row-v2 > .icon--caret {
  color: var(--loma-text-muted);
  /* Item 3 (v2.1): Caret echt in der Tile-Mitte (nicht an der Titel-Grundlinie) —
     konsistent über ein- und mehrzeilige Rows. Status-Indikator bleibt titelbündig. */
  align-self: center;
  margin-top: 0;
}
.row-v2 .icon--caret { width: 1.25rem; height: 1.25rem; }

/* Status-Indikator — Form UND Farbe */
.row-v2__status {
  width: var(--loma-indicator);
  height: var(--loma-indicator);
  flex: none;
  display: grid;
  place-items: center;
  border-radius: var(--loma-radius-round);
  margin-top: calc((var(--loma-text-md) * 1.3 - var(--loma-indicator)) / 2);
}
.row-v2__status .icon { width: 60%; height: 60%; stroke-width: 1.75; }
.row-v2__status--waiting { background: var(--loma-surface-sunken); color: var(--loma-text-secondary); }
.row-v2__status--done { background: var(--loma-status-ok-soft); color: var(--loma-status-ok-text); }
.row-v2__status--open { background: var(--loma-area-vollmacht-soft); color: var(--loma-area-vollmacht-text); }

/* Fortschrittsring (--p = 0..1; Mindestsegment 8 %) */
.row-v2__ring {
  width: var(--loma-indicator);
  height: var(--loma-indicator);
  transform: rotate(-90deg);
  flex: none;
  margin-top: calc((var(--loma-text-md) * 1.3 - var(--loma-indicator)) / 2);
}
.row-v2__ring circle { fill: none; stroke-width: 3; }
.row-v2__ring .track { stroke: var(--loma-surface-sunken); }
.row-v2__ring .fill {
  stroke: var(--loma-area-vollmacht);
  stroke-linecap: round;
  stroke-dasharray: 75.4;
  stroke-dashoffset: calc(75.4 * (1 - max(var(--p, 0), 0.08)));
}

/* ---- Horizontaler Vorgangs-Streifen (F3, Mobile-Pattern) ----
   Karten scrollen mit Snap; die nächste lugt am Rand hervor (Edge-Peek =
   sichtbarer Scroll-Hinweis). Status-Indikator bleibt je Karte erhalten. */
.hscroll {
  display: flex;
  gap: var(--loma-space-3);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  /* über den 1.25rem-Content-Gutter ausbrechen: erste Karte bündig, letzte peekt */
  margin: 0 -1.25rem;
  padding: var(--loma-space-1) 1.25rem var(--loma-space-2);
}
.hscroll::-webkit-scrollbar { display: none; }
.hscroll__card {
  scroll-snap-align: start;
  flex: 0 0 76%;
  display: flex;
  flex-direction: column;
  gap: var(--loma-space-3);
  padding: var(--loma-space-4);
  background: var(--loma-surface-card);
  border-radius: var(--loma-radius-card);
  box-shadow: var(--loma-elevation-1);
  text-decoration: none;
  color: inherit;
  transition: transform var(--loma-duration-tap) var(--loma-ease-out);
}
.hscroll__card:active { transform: scale(0.99); background: var(--loma-state-pressed); }
.hscroll__card .row-v2__ring,
.hscroll__card .row-v2__status { margin-top: 0; }
.hscroll__body { flex: 1; min-width: 0; }
.hscroll__title { margin: 0; font-size: var(--loma-text-lg); font-weight: 700; line-height: 1.25; }
.hscroll__caption { margin: var(--loma-space-1) 0 0; font-size: var(--loma-text-sm); color: var(--loma-text-secondary); line-height: 1.4; }
.hscroll__caption b { font-weight: 600; color: var(--loma-text-primary); }
.hscroll__open {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--loma-text-sm);
  font-weight: 600;
  color: var(--loma-action-warm);
}
.hscroll__open .icon--caret { width: 1rem; height: 1rem; }

/* ---- Formularfelder ---- */
.field { display: block; }
.field + .field { margin-top: var(--loma-space-3); }
.field__label {
  display: block;
  margin: 0 0 var(--loma-space-1);
  padding: 0 var(--loma-space-1);
  font-size: var(--loma-text-sm);
  font-weight: 600;
  color: var(--loma-text-secondary);
}
.field__control {
  width: 100%;
  min-height: var(--loma-touch-target);
  padding: var(--loma-space-2) var(--loma-space-3);
  border: var(--loma-hairline) solid var(--loma-border-subtle);
  border-radius: var(--loma-radius-input);
  background: var(--loma-surface-card);
  color: var(--loma-text-primary);
  font-family: var(--loma-font-product);
  font-size: var(--loma-text-md);
}
.field__control::placeholder { color: var(--loma-text-muted); }
.field__hint {
  margin: var(--loma-space-1) 0 0;
  padding: 0 var(--loma-space-1);
  font-size: var(--loma-text-sm);
  color: var(--loma-text-muted);
}

/* ---- Auswahl-Optionen (Akutbaum, Tagescheck) — grosse Tap-Karten ---- */
.choice {
  display: flex;
  align-items: center;
  gap: var(--loma-space-3);
  width: 100%;
  min-width: 0;
  min-height: var(--loma-touch-target);
  padding: var(--loma-space-3) var(--loma-space-4);
  border: 0;
  border-radius: var(--loma-radius-card);
  background: var(--loma-surface-card);
  box-shadow: var(--loma-elevation-1);
  color: var(--loma-text-primary);
  font-family: var(--loma-font-product);
  font-size: clamp(1rem, 4.2vw, var(--loma-text-md));
  font-weight: 600;
  line-height: 1.3;
  text-align: left;
  text-decoration: none;
  overflow-wrap: anywhere;
  cursor: pointer;
  transition: background var(--loma-duration-tap) var(--loma-ease-out),
              transform var(--loma-duration-tap) var(--loma-ease-out);
}
.choice + .choice { margin-top: var(--loma-space-2); }
.choice:active { background: var(--loma-surface-warm); transform: scale(0.995); }
.choice__icon {
  display: inline-grid;
  place-items: center;
  width: var(--loma-icon-tile);
  height: var(--loma-icon-tile);
  flex: none;
  border-radius: var(--loma-radius-icon);
  background: var(--loma-surface-sunken);
  color: var(--loma-text-secondary);
}
.choice__body { flex: 1; min-width: 0; overflow-wrap: anywhere; }
.choice__body small {
  display: block;
  margin-top: 2px;
  font-size: clamp(0.875rem, 3.8vw, var(--loma-text-sm));
  font-weight: 400;
  line-height: 1.35;
  color: var(--loma-text-secondary);
}
.choice > .icon--caret { color: var(--loma-text-muted); flex: none; }
[data-selected="true"].choice { box-shadow: var(--loma-state-selected-ring), var(--loma-elevation-1); }

/* ---- Messwert-Eingaben (Tagescheck-MVP) ---- */
.metric-card {
  display: flex;
  flex-direction: column;
  gap: var(--loma-space-4);
  padding: var(--loma-space-4);
  border-radius: var(--loma-radius-card-lg);
  background: var(--loma-surface-card);
  box-shadow: var(--loma-elevation-1);
}
.metric-value {
  margin: 0;
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: var(--loma-space-2);
  font-family: var(--loma-font-brand);
  font-size: var(--loma-text-value-lg);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  font-feature-settings: var(--loma-numeric-features);
}
.metric-value small {
  font-family: var(--loma-font-product);
  font-size: var(--loma-text-md);
  font-weight: 700;
  color: var(--loma-text-secondary);
}
.metric-stepper {
  display: grid;
  grid-template-columns: var(--loma-touch-target) 1fr var(--loma-touch-target);
  align-items: center;
  gap: var(--loma-space-3);
}
.metric-stepper__btn {
  width: var(--loma-touch-target);
  height: var(--loma-touch-target);
  border: 0;
  border-radius: var(--loma-radius-round);
  background: var(--loma-surface-sunken);
  color: var(--loma-text-primary);
  font: inherit;
  font-size: var(--loma-text-xl);
  font-weight: 700;
}
.metric-stepper__track {
  height: 8px;
  border-radius: var(--loma-radius-round);
  background: var(--loma-surface-sunken);
  overflow: hidden;
}
.metric-stepper__fill {
  display: block;
  height: 100%;
  width: var(--p);
  border-radius: inherit;
  background: var(--loma-brand-sage-dark);
}
.metric-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--loma-space-3);
}
.metric-field {
  min-height: 116px;
  padding: var(--loma-space-3);
  border-radius: var(--loma-radius-card);
  background: var(--loma-surface-warm);
}
.metric-field__label {
  margin: 0 0 var(--loma-space-2);
  font-size: var(--loma-text-sm);
  font-weight: 700;
  color: var(--loma-text-secondary);
}
.metric-field__value {
  margin: 0;
  font-family: var(--loma-font-brand);
  font-size: var(--loma-text-value);
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.metric-scale {
  display: flex;
  justify-content: space-between;
  gap: var(--loma-space-2);
  font-size: var(--loma-text-xs);
  font-weight: 700;
  color: var(--loma-text-muted);
}

/* ---- Frage-Heading (1-Frage-Flows: Akutbaum, Tagescheck) ---- */
.ask { margin: var(--loma-space-2) 0 var(--loma-space-1); }
.ask__title {
  margin: 0;
  font-family: var(--loma-font-brand);
  font-size: clamp(1.6rem, 6.5vw, 2rem);
  font-weight: 700;
  line-height: var(--loma-line-heading);
  letter-spacing: -0.01em;
  text-wrap: balance;
}
.ask__sub {
  margin: var(--loma-space-2) 0 0;
  max-width: 32ch;
  font-size: var(--loma-text-md);
  line-height: var(--loma-line-body);
  color: var(--loma-text-secondary);
}
/* Schritt-/Frage-Zähler unter dem Step-Indicator */
.step-caption {
  margin: var(--loma-space-2) 0 0;
  text-align: center;
  font-size: var(--loma-text-sm);
  font-weight: 600;
  color: var(--loma-text-secondary);
}

/* ---- 112-Notruf-Leiste (Akut-Einstieg + Sturz-Flow) — der EINZIGE rote Moment ---- */
.emergency {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--loma-space-3);
  min-width: 0;
  min-height: 56px;
  padding: var(--loma-space-2) var(--loma-space-3);
  border-radius: var(--loma-radius-card);
  background: var(--loma-112-bg);
  color: var(--loma-112-text);
  text-decoration: none;
  overflow-wrap: anywhere;
  box-shadow: var(--loma-elevation-1); /* hebt den 112-Streifen als eigene Fläche ab — klar getrennt von den warmen Akut-Kacheln */
}
.emergency--dock {
  position: absolute;
  left: 1.25rem;
  right: 1.25rem;
  bottom: calc(var(--loma-space-3) + env(safe-area-inset-bottom));
  z-index: calc(var(--loma-z-tabbar) - 1);
}
.emergency--tabbar {
  bottom: calc(var(--loma-shell-tabbar-height) + var(--loma-tabbar-bottom-gap) + var(--loma-space-2) + env(safe-area-inset-bottom));
}
.emergency--dock {
  grid-template-columns: minmax(0, 1fr);
}
.emergency--dock .emergency__badge { display: none; }
.emergency--dock .emergency__num { display: none; }
.emergency--dock .emergency__title { color: var(--loma-action-emergency); }
.emergency--dock .emergency__sub {
  font-size: clamp(0.8125rem, 3.4vw, var(--loma-text-sm));
}
.shell-content--with-emergency {
  padding-bottom: calc(var(--loma-space-5) + 6.5rem + env(safe-area-inset-bottom));
}
.shell-content--with-emergency:not(.shell-content--flow) {
  padding-bottom: calc(var(--loma-shell-tabbar-height) + var(--loma-space-5) + 6.5rem + env(safe-area-inset-bottom));
}
.emergency:active { background: var(--loma-status-alert-soft); filter: brightness(0.98); }
.emergency__badge {
  display: inline-grid;
  place-items: center;
  width: 40px;
  height: 40px;
  flex: none;
  border-radius: var(--loma-radius-icon);
  background: var(--loma-112-accent);
  color: var(--loma-action-emergency-text);
}
.emergency__body { flex: 1; min-width: 0; overflow-wrap: anywhere; }
.emergency__title { margin: 0; font-size: clamp(1rem, 4vw, var(--loma-text-md)); font-weight: 700; line-height: 1.25; }
.emergency__sub { margin: 2px 0 0; font-size: clamp(0.875rem, 3.6vw, var(--loma-text-sm)); color: var(--loma-text-secondary); line-height: 1.35; }
.emergency__num {
  font-family: var(--loma-font-brand);
  font-size: clamp(1.125rem, 5vw, var(--loma-text-lg));
  font-weight: 800;
  color: var(--loma-112-accent);
  font-variant-numeric: tabular-nums;
  line-height: 1;
  min-width: 0;
}
.emergency-note {
  margin: calc(-1 * var(--loma-space-2)) 0 0;
  font-size: var(--loma-text-sm);
  line-height: var(--loma-line-body);
  color: var(--loma-text-secondary);
}

/* De-Eskalations-Pfad „kein Notfall" — ruhige weiße Row, voll lesbar */
.offramp { display: flex; align-items: center; gap: var(--loma-space-3); padding: var(--loma-space-3) var(--loma-space-4); border-radius: var(--loma-radius-card); background: var(--loma-surface-card); box-shadow: var(--loma-elevation-1); text-decoration: none; color: inherit; min-height: var(--loma-touch-target); }
.offramp:active { background: var(--loma-surface-warm); }
.offramp__body { flex: 1; min-width: 0; }
.offramp__body strong { display: block; font-size: var(--loma-text-md); font-weight: 600; }
.offramp__body small { display: block; margin-top: 2px; font-size: var(--loma-text-sm); color: var(--loma-text-secondary); }
.offramp__num { font-family: var(--loma-font-brand); font-size: var(--loma-text-lg); font-weight: 700; color: var(--loma-text-secondary); font-variant-numeric: tabular-nums; white-space: nowrap; }

/* Medizin-Draft-Marker für Akutbäume bis Johan-Sign-off. */
.medical-review {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  min-height: 28px;
  padding: 0 var(--loma-space-2);
  border-radius: var(--loma-radius-badge);
  background: var(--loma-surface-sunken);
  color: var(--loma-text-secondary);
  font-size: var(--loma-text-xs);
  font-weight: 700;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

/* Großer 112-Call-to-Action auf Notruf-Ergebnisseiten. */
.call112 {
  background: var(--loma-action-emergency);
  color: var(--loma-action-emergency-text);
  min-height: 60px;
  font-size: clamp(1.0625rem, 4.8vw, var(--loma-text-lg));
  line-height: 1.2;
  box-shadow: var(--loma-elevation-2);
  gap: var(--loma-space-3);
}
.call112:hover { background: var(--loma-action-emergency-hover); }
.call112:active { background: var(--loma-action-emergency-hover); }
.call112 .num {
  font-family: var(--loma-font-brand);
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}

/* ---- „So geht's"-Schritte (nummerierte Anleitung, z.B. Aufhelfen) ---- */
.howto { margin: 0; padding: 0; list-style: none; counter-reset: howto; }
.howto__item { display: flex; align-items: flex-start; gap: var(--loma-space-3); padding: var(--loma-density-card) 0; }
.howto__item + .howto__item { border-top: var(--loma-hairline) solid var(--loma-border-soft); }
.howto__num {
  counter-increment: howto;
  width: 1.75rem; height: 1.75rem; flex: none;
  display: grid; place-items: center;
  border-radius: var(--loma-radius-round);
  background: var(--loma-area-vollmacht-soft);
  color: var(--loma-area-vollmacht-text);
  font-weight: 700; font-size: var(--loma-text-sm);
}
.howto__num::before { content: counter(howto); }
.howto__text { flex: 1; min-width: 0; font-size: var(--loma-text-md); line-height: var(--loma-line-body); padding-top: 2px; }

/* ---- Ampel (Tagescheck-Ergebnis, Akut-Status) ---- */
.ampel {
  display: inline-flex;
  align-items: center;
  gap: var(--loma-space-2);
  padding: var(--loma-space-1) var(--loma-space-3);
  border-radius: var(--loma-radius-badge);
  font-size: var(--loma-text-sm);
  font-weight: 600;
}
.ampel__dot { width: 10px; height: 10px; border-radius: var(--loma-radius-round); flex: none; }
.ampel--ok   { background: var(--loma-status-ok-soft);   color: var(--loma-status-ok-text); }
.ampel--ok   .ampel__dot { background: var(--loma-status-ok); }
.ampel--warn { background: var(--loma-status-warn-soft); color: var(--loma-status-warn-text); }
.ampel--warn .ampel__dot { background: var(--loma-status-warn); }
.ampel--alert{ background: var(--loma-status-alert-soft);color: var(--loma-status-alert-text); }
.ampel--alert .ampel__dot { background: var(--loma-status-alert); }
/* Neutral — sachlicher Status ohne Warn-Konnotation (z.B. „Wird geprüft") */
.ampel--neutral { background: var(--loma-surface-sunken); color: var(--loma-text-secondary); }
.ampel--neutral .ampel__dot { background: var(--loma-text-muted); }

/* Grosser zentrierter Ampel-Kreis (Tagescheck-Ergebnis-Held) */
.ampel-disc {
  display: grid;
  place-items: center;
  width: 132px;
  height: 132px;
  margin: 0 auto;
  border-radius: var(--loma-radius-round);
}
.ampel-disc .icon { width: 56px; height: 56px; stroke-width: 2; }
.ampel-disc--ok   { background: var(--loma-status-ok-soft);   color: var(--loma-status-ok-text); }
.ampel-disc--warn { background: var(--loma-status-warn-soft); color: var(--loma-status-warn-text); }

/* ---- Step-Indicator (Flow-Fortschritt: Punkte) ---- */
.steps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--loma-space-2);
  margin: 0;
  padding: 0;
  list-style: none;
}
.steps__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--loma-radius-round);
  background: var(--loma-surface-sunken);
}
.steps__dot[aria-current="step"] { background: var(--loma-area-vollmacht); width: 22px; }
.steps__dot[data-done="true"] { background: var(--loma-area-vollmacht); opacity: 0.45; }

/* ---- Summary-Zeile (Unterschrift-Übersicht, Profil) ---- */
.summary { display: flex; flex-direction: column; }
.summary__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--loma-space-3);
  padding: var(--loma-density-card) 0;
}
.summary__row + .summary__row { border-top: var(--loma-hairline) solid var(--loma-border-soft); }
.summary__key { font-size: var(--loma-text-sm); color: var(--loma-text-secondary); }
.summary__val { font-size: var(--loma-text-md); font-weight: 600; text-align: right; }
.summary__val--num { font-variant-numeric: tabular-nums; font-feature-settings: var(--loma-numeric-features); }

/* ---- Zahlen-Held (Beträge prominent) ---- */
.value-hero {
  font-family: var(--loma-font-brand);
  font-size: var(--loma-text-value-lg);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  font-feature-settings: var(--loma-numeric-features);
}

/* ---- Bottom-Tabs ---- */
.shell-tabbar {
  position: absolute;
  bottom: calc(var(--loma-tabbar-bottom-gap) + env(safe-area-inset-bottom));
  left: max(var(--loma-tabbar-side-inset), env(safe-area-inset-left));
  right: max(var(--loma-tabbar-side-inset), env(safe-area-inset-right));
  z-index: var(--loma-z-tabbar);
  view-transition-name: --vt-tabbar;
  isolation: isolate;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
  column-gap: var(--loma-space-1);
  /* Tabbar-Glas: Auf iOS Safari macht zu viel Blur über Off-White alles milchig.
     Deshalb: weniger Blur, weniger Deckkraft, stärkere Glasränder und Caustics,
     damit Hintergrundformen sichtbar bleiben. */
  overflow: hidden;
  background:
    linear-gradient(112deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 18%, rgba(255, 255, 255, 0.42) 28%, rgba(255, 255, 255, 0.06) 39%, rgba(255, 255, 255, 0) 52%),
    radial-gradient(140% 120% at 50% -22%, rgba(255, 255, 255, 0.38) 0%, rgba(255, 255, 255, 0.12) 34%, rgba(255, 255, 255, 0) 66%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.10) 0%, var(--loma-glass-tabbar-bg) 46%, rgba(236, 233, 227, 0.10) 100%),
    linear-gradient(180deg, rgba(230, 238, 224, 0.16) 0%, rgba(87, 83, 75, 0.07) 100%);
  background-blend-mode: screen, screen, normal, multiply;
  -webkit-backdrop-filter: blur(22px) saturate(220%) contrast(1.18) brightness(1.06);
  backdrop-filter: blur(22px) saturate(220%) contrast(1.18) brightness(1.06);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.98),
    inset 0 0 0 1px rgba(255, 255, 255, 0.74),
    inset 0 0 0 2px rgba(79, 92, 78, 0.06),
    inset 0 -1px 0 rgba(27, 26, 24, 0.13),
    inset 0 -18px 30px rgba(27, 26, 24, 0.075),
    0 -1px 0 rgba(255, 255, 255, 0.58),
    0 -16px 42px rgba(27, 26, 24, 0.22),
    0 16px 38px rgba(27, 26, 24, 0.16);
  border-radius: var(--loma-radius-sheet);
  min-height: var(--loma-shell-tabbar-height);
  padding: 0.375rem 0.625rem;
}
.shell-tabbar::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  background:
    linear-gradient(108deg, rgba(255, 255, 255, 0.78) 0%, rgba(255, 255, 255, 0.10) 18%, rgba(255, 255, 255, 0) 31%, rgba(255, 255, 255, 0.44) 62%, rgba(255, 255, 255, 0) 78%),
    linear-gradient(252deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 58%, rgba(255, 255, 255, 0.30) 69%, rgba(255, 255, 255, 0) 82%),
    radial-gradient(85% 100% at 50% 100%, rgba(27, 26, 24, 0.20) 0%, rgba(27, 26, 24, 0) 58%),
    linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(79, 92, 78, 0.09) 100%);
  opacity: 0.96;
  pointer-events: none;
}
.shell-tabbar::after {
  content: "";
  position: absolute;
  inset: 0.0625rem 0.875rem auto;
  height: 1.35rem;
  z-index: 0;
  border-radius: var(--loma-radius-round);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.20) 52%, rgba(255, 255, 255, 0));
  pointer-events: none;
}
.shell-tab {
  position: relative;
  z-index: 1;
  isolation: isolate;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  min-height: var(--loma-touch-target);
  min-width: 0;
  padding: 0.35rem 0.25rem;
  border: 0;
  border-radius: var(--loma-radius-card);
  background: transparent;
  color: var(--loma-text-secondary);
  font-family: var(--loma-font-product);
  font-size: 0.7rem;
  font-weight: 500;
  line-height: 1.1;
  text-decoration: none;
  cursor: pointer;
  touch-action: manipulation;
  transition:
    color var(--loma-duration-fast) var(--loma-ease-out),
    transform var(--loma-duration-tap) var(--loma-ease-out);
}
.shell-tab::before {
  content: "";
  position: absolute;
  inset: 0.125rem 0.25rem;
  z-index: 0;
  border-radius: var(--loma-radius-round);
  background: transparent;
  opacity: 0;
  transform: scale(0.94);
  transition:
    opacity var(--loma-duration-fast) var(--loma-ease-out),
    transform var(--loma-duration-fast) var(--loma-ease-out),
    background var(--loma-duration-fast) var(--loma-ease-out);
}
.shell-tab .icon {
  width: var(--loma-icon-md);
  height: var(--loma-icon-md);
  color: inherit;
  opacity: 0.82;
  transition:
    opacity var(--loma-duration-fast) var(--loma-ease-out),
    transform var(--loma-duration-fast) var(--loma-ease-out);
}
.shell-tab > .icon,
.shell-tab > span:first-of-type {
  position: relative;
  z-index: 1;
}
.shell-tab > span:first-of-type { max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; letter-spacing: 0; }
.shell-tab:active { transform: scale(0.985); }
.shell-tab:active::before {
  background: var(--loma-tabbar-press-bg);
  opacity: 1;
  transform: scale(1);
}
.shell-tab[aria-current="page"] {
  color: var(--loma-brand-sage-dark);
  font-weight: 700;
}
.shell-tab[aria-current="page"]::before {
  background:
    radial-gradient(120% 120% at 50% 0%, rgba(255, 255, 255, 0.72) 0%, rgba(255, 255, 255, 0.26) 44%, rgba(255, 255, 255, 0) 76%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.36) 0%, var(--loma-tabbar-active-bg) 100%);
  -webkit-backdrop-filter: blur(12px) saturate(170%) contrast(1.08) brightness(1.06);
  backdrop-filter: blur(12px) saturate(170%) contrast(1.08) brightness(1.06);
  box-shadow: var(--loma-tabbar-active-shadow);
  opacity: 1;
  transform: scale(1);
}
.shell-tab[aria-current="page"] .icon {
  fill: currentColor;
  stroke: currentColor;
  opacity: 1;
  transform: translateY(-1px);
}

/* ---- Icons ---- */
.icon {
  width: var(--loma-icon-md);
  height: var(--loma-icon-md);
  fill: none;
  stroke: currentColor;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex: none;
}
.icon--sm { width: var(--loma-icon-sm); height: var(--loma-icon-sm); }
.icon--lg { width: var(--loma-icon-lg); height: var(--loma-icon-lg); }

/* Globaler Focus-Ring (ein Ring für alles Fokussierbare) */
:where(a, button, input, [tabindex]):focus-visible {
  outline: var(--loma-focus-ring) solid var(--loma-focus);
  outline-offset: var(--loma-focus-offset);
  border-radius: var(--loma-radius-input);
}
