/*
 * habit — Papier-/Bullet-Journal-Ästhetik.
 * Warmes Off-White, dezente Rasterlinien, ruhige Typografie.
 * Kein Framework, kein Build-Step.
 */

:root {
    --paper: #f6f1e7;
    --paper-line: rgba(60, 47, 30, 0.08);
    --ink: #241d17;
    --ink-mute: #6b5f52;
    --ink-faint: #a89d90;
    --accent-private: #6a5f9b;
    --accent-work: #9b6a5f;
    --card: #fbf7ee;
    --card-line: rgba(60, 47, 30, 0.14);
    --focus: #8a7a3b;
    --danger: #a83a2b;
    --success: #4c7a3a;
    --radius: 12px;
    --gap: 16px;
    --shell-pad: 20px;
    --serif: 'Iowan Old Style', 'Palatino Linotype', 'Book Antiqua', Palatino, 'Georgia', serif;
    --sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Inter', 'Helvetica Neue', Arial, sans-serif;
}

@media (prefers-color-scheme: dark) {
    :root {
        --paper: #141210;
        --paper-line: rgba(240, 230, 210, 0.06);
        --ink: #ece4d4;
        --ink-mute: #a89e8c;
        --ink-faint: #6b6355;
        --card: #1c1915;
        --card-line: rgba(240, 230, 210, 0.10);
        --accent-private: #b0a4de;
        --accent-work: #dea69b;
        --success: #96c07f;
        --danger: #d97b6b;
    }
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    background: var(--paper);
    color: var(--ink);
    font-family: var(--sans);
    font-size: 17px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
}

body.paper {
    height: 100vh;
    height: 100dvh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding-bottom: env(safe-area-inset-bottom);
}

.shell {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    max-width: 560px;
    width: 100%;
    margin: 0 auto;
    padding: var(--shell-pad);
    padding-top: calc(var(--shell-pad) + env(safe-area-inset-top));
    padding-bottom: var(--shell-pad);
    background-image: linear-gradient(var(--paper-line) 1px, transparent 1px);
    background-size: 100% 32px;
    background-position: 0 24px;
    background-attachment: local;
}

.stack { display: flex; flex-direction: column; gap: 24px; }
.stack-tight { display: flex; flex-direction: column; gap: 8px; }

.eyebrow {
    font-family: var(--serif);
    font-style: italic;
    font-size: 14px;
    color: var(--ink-mute);
    letter-spacing: 0.02em;
    margin: 0;
}

.display {
    font-family: var(--serif);
    font-weight: 500;
    font-size: 32px;
    line-height: 1.15;
    color: var(--ink);
    margin: 0;
    letter-spacing: -0.01em;
}

.lede {
    color: var(--ink-mute);
    font-size: 17px;
    margin: 0;
    max-width: 42ch;
}

.card {
    background: var(--card);
    border: 1px solid var(--card-line);
    border-radius: var(--radius);
    padding: 16px 18px;
}

.card-label {
    font-family: var(--serif);
    font-style: italic;
    color: var(--ink-mute);
    font-size: 13px;
    margin: 0 0 4px;
}

.foot { color: var(--ink-faint); font-size: 14px; }

a.ghost {
    color: var(--ink-mute);
    text-decoration: none;
    border-bottom: 1px dotted var(--ink-faint);
}
a.ghost:hover { color: var(--ink); }

button, .btn {
    font: inherit;
    background: var(--ink);
    color: var(--paper);
    border: 0;
    border-radius: var(--radius);
    padding: 12px 18px;
    min-height: 44px;
    cursor: pointer;
    transition: transform 80ms ease, background 120ms ease;
}
button:hover, .btn:hover { background: #000; }
@media (prefers-color-scheme: dark) {
    button:hover, .btn:hover { background: #fff; color: #000; }
}
button:active { transform: translateY(1px); }
button:focus-visible, .btn:focus-visible, a:focus-visible {
    outline: 2px solid var(--focus);
    outline-offset: 2px;
}

/* --- Touch-Optimierung (Mobile) --- */
/* Entfernt die 300ms-Tap-Verzögerung und den grauen Tap-Flash; wir nutzen
   eigene :active-Zustände. user-select verhindert versehentliches Markieren
   beim schnellen Antippen. */
button, .btn, .tap, .chip, .icon-btn, .nav-item,
.menu-pop button, .menu-pop a, a.ghost, .copy-btn, summary, label.checkbox-inline {
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}
.tap, .icon-btn, .nav-item, .chip {
    -webkit-user-select: none;
    user-select: none;
}

/* --- Formulare --- */

.form { display: flex; flex-direction: column; gap: 18px; }

.field { display: flex; flex-direction: column; gap: 6px; }

.field label {
    font-family: var(--serif);
    font-style: italic;
    color: var(--ink-mute);
    font-size: 14px;
    letter-spacing: 0.02em;
}

.field input,
.field select,
.field textarea {
    font: inherit;
    color: var(--ink);
    background: var(--card);
    border: 1px solid var(--card-line);
    border-bottom: 1px solid var(--ink-faint);
    border-radius: 8px;
    padding: 12px 14px;
    min-height: 44px;
    -webkit-appearance: none;
    appearance: none;
}
.field select { padding-right: 32px; background-image: linear-gradient(45deg, transparent 50%, var(--ink-mute) 50%), linear-gradient(-45deg, transparent 50%, var(--ink-mute) 50%); background-position: right 14px center, right 8px center; background-size: 6px 6px, 6px 6px; background-repeat: no-repeat; }
.field input:focus-visible,
.field select:focus-visible,
.field textarea:focus-visible {
    outline: 2px solid var(--focus);
    outline-offset: 2px;
    border-color: transparent;
}

.checkbox-inline {
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: var(--sans);
    font-style: normal;
    color: var(--ink);
    font-size: 15px;
    cursor: pointer;
}
.checkbox-inline input[type="checkbox"] {
    width: 20px;
    height: 20px;
    accent-color: var(--ink);
    -webkit-appearance: auto;
    appearance: auto;
    margin: 0;
    min-height: 0;
}

[x-cloak] { display: none !important; }

.field .hint {
    color: var(--ink-faint);
    font-size: 13px;
}

.field .error {
    color: var(--danger);
    font-size: 14px;
}

.field.honeypot {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.actions { display: flex; align-items: center; justify-content: space-between; gap: 12px; }

/* --- Bottom-Navigation --- */

.nav {
    flex: 0 0 auto;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 4px;
    padding: 8px;
    background: var(--paper);
    border-top: 1px solid var(--card-line);
}

.nav-item {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 8px 6px;
    border-radius: 10px;
    color: var(--ink-mute);
    text-decoration: none;
    font-family: var(--serif);
    font-size: 14px;
    letter-spacing: 0.02em;
}

.nav-item:hover  { color: var(--ink); }
.nav-item--active {
    color: var(--ink);
    background: var(--card);
    border: 1px solid var(--card-line);
}

/* --- Ziele-Liste + Formular-spezifisch --- */

.goal-list { display: flex; flex-direction: column; gap: 12px; }

.goal-card {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px;
    background: var(--card);
    border: 1px solid var(--card-line);
    border-radius: var(--radius);
}
.goal-card__title { font-family: var(--serif); font-size: 18px; margin: 0 0 4px; color: var(--ink); }
.goal-card__meta  { font-size: 13px; color: var(--ink-mute); margin: 0; }
.goal-card__actions { display: flex; gap: 8px; flex-shrink: 0; }
.goal-card__badge {
    display: inline-block;
    font-size: 12px;
    padding: 2px 8px;
    border-radius: 999px;
    color: var(--paper);
    background: var(--ink);
    margin-left: 6px;
    letter-spacing: 0.02em;
}
.goal-card__badge--privat    { background: var(--accent-private); }
.goal-card__badge--beruflich { background: var(--accent-work); }
.goal-card__badge--shared    { background: transparent; color: var(--ink-mute); border: 1px solid var(--card-line); }
.goal-card--archived .goal-card__title { color: var(--ink-faint); }

.icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    color: var(--ink-mute);
    border: 1px solid var(--card-line);
    padding: 8px 12px;
    min-height: 44px;
    min-width: 44px;
    border-radius: 8px;
    font-size: 13px;
}
.icon-btn:hover { color: var(--ink); background: var(--card); }

.section-title {
    font-family: var(--serif);
    font-style: italic;
    color: var(--ink-mute);
    font-size: 14px;
    letter-spacing: 0.02em;
    margin: 8px 0 4px;
}

/* --- Heute-Screen --- */

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

.today-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 16px 16px;
    background: var(--card);
    border: 1px solid var(--card-line);
    border-radius: var(--radius);
    transition: opacity 200ms ease;
}
.today-card--done { opacity: 0.72; }

.today-card__body { flex: 1 1 auto; min-width: 0; }
.today-card__title {
    font-family: var(--serif);
    font-size: 18px;
    margin: 0 0 4px;
    color: var(--ink);
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.today-card__meta { font-size: 13px; color: var(--ink-mute); margin: 0 0 8px; }

.progress {
    width: 100%;
    height: 6px;
    background: color-mix(in srgb, var(--paper-line) 100%, transparent);
    border-radius: 999px;
    overflow: hidden;
    margin-top: 4px;
}
.progress__bar {
    height: 100%;
    background: var(--ink);
    border-radius: 999px;
    transition: width 240ms ease;
}

.today-card__actions { flex-shrink: 0; display: flex; align-items: center; gap: 8px; }

.tap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 52px;
    min-height: 52px;
    padding: 0 14px;
    background: transparent;
    color: var(--ink);
    border: 2px solid var(--ink);
    border-radius: 14px;
    font-family: var(--serif);
    font-size: 18px;
    cursor: pointer;
    transition: transform 100ms ease, background 160ms ease, color 160ms ease;
}
.tap:hover { background: var(--ink); color: var(--paper); }
.tap:active { transform: scale(0.96); }
.tap[disabled] {
    opacity: 0.35;
    cursor: not-allowed;
    background: transparent;
    color: var(--ink-mute);
    border-color: var(--ink-mute);
}

.tap--check {
    padding: 0;
    min-width: 52px;
}
.tap--check svg { display: block; }
.tap--check.tap--checked {
    background: var(--ink);
    color: var(--paper);
}
@media (prefers-color-scheme: dark) {
    .tap:hover, .tap--check.tap--checked { background: var(--ink); color: var(--paper); }
}

.tap-group { display: inline-flex; gap: 6px; }
.tap--plus { font-weight: 500; }
.tap--minus {
    min-width: 44px;
    min-height: 52px;
    padding: 0 12px;
    border-color: var(--ink-mute);
    color: var(--ink-mute);
}
.tap--minus:hover { background: var(--ink-mute); color: var(--paper); }

.goal-card__badge--warn {
    background: transparent;
    color: var(--danger);
    border: 1px solid var(--danger);
}

/* --- Kontext-Menü + Datepicker-Zeile --- */

.today-card__menu {
    position: relative;
    display: inline-block;
}
.today-card__menu .icon-btn {
    min-height: 44px;
    padding: 0 10px;
    font-size: 20px;
    line-height: 1;
}

.menu-pop {
    position: absolute;
    right: 0;
    top: calc(100% + 6px);
    z-index: 20;
    display: flex;
    flex-direction: column;
    background: var(--card);
    border: 1px solid var(--card-line);
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    min-width: 220px;
    padding: 6px;
}
.menu-pop button,
.menu-pop a {
    display: block;
    width: 100%;
    background: transparent;
    color: var(--ink);
    border: 0;
    text-align: left;
    padding: 10px 12px;
    border-radius: 6px;
    font-family: var(--sans);
    font-size: 15px;
    min-height: 40px;
    line-height: 20px;
    cursor: pointer;
    text-decoration: none;
}
.menu-pop a { text-decoration: none; }
.menu-pop button:hover,
.menu-pop a:hover { background: color-mix(in srgb, var(--paper-line) 100%, transparent); }
.menu-pop form { margin: 0; }
.menu-pop button.is-danger { color: var(--danger); }

.row-menu {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 12px;
    padding: 10px 12px;
    background: color-mix(in srgb, var(--paper-line) 80%, transparent);
    border-radius: 8px;
    flex-wrap: wrap;
}
.row-menu__label {
    font-family: var(--serif);
    font-style: italic;
    color: var(--ink-mute);
    font-size: 14px;
}
.row-menu input[type="date"] {
    font: inherit;
    color: var(--ink);
    background: var(--card);
    border: 1px solid var(--card-line);
    border-radius: 6px;
    padding: 8px 10px;
    min-height: 40px;
}

/* --- Rückblick --- */

.chip-row {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.chip {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 8px 16px;
    border-radius: 999px;
    background: var(--card);
    border: 1px solid var(--card-line);
    color: var(--ink-mute);
    text-decoration: none;
    font-family: var(--serif);
    font-size: 14px;
}
.chip:hover { color: var(--ink); }
.chip--active {
    background: var(--ink);
    color: var(--paper);
    border-color: var(--ink);
}

.review-card {
    background: var(--card);
    border: 1px solid var(--card-line);
    border-radius: var(--radius);
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.review-card__head { display: flex; flex-direction: column; gap: 4px; }
.review-card__title {
    font-family: var(--serif);
    font-size: 20px;
    color: var(--ink);
    margin: 0;
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.review-card__meta { margin: 0; color: var(--ink-mute); font-size: 13px; }

.review-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px 16px;
    padding: 4px 0;
}
@media (min-width: 480px) {
    .review-stats { grid-template-columns: repeat(4, 1fr); }
}
.stat { display: flex; flex-direction: column; gap: 2px; }
.stat__value {
    font-family: var(--serif);
    font-size: 26px;
    line-height: 1.1;
    color: var(--ink);
}
.stat__label {
    font-family: var(--serif);
    font-style: italic;
    font-size: 12px;
    color: var(--ink-mute);
}

.heatmap-wrap { display: flex; flex-direction: column; gap: 6px; overflow-x: auto; }
.heatmap { width: 100%; height: auto; max-width: 100%; }
.heatmap rect { transition: opacity 120ms ease; }
.heat.heat--l0     { fill: color-mix(in srgb, var(--paper-line) 100%, transparent); }
.heat.heat--l1     { fill: color-mix(in srgb, var(--ink) 20%, transparent); }
.heat.heat--l2     { fill: color-mix(in srgb, var(--ink) 40%, transparent); }
.heat.heat--l3     { fill: color-mix(in srgb, var(--ink) 65%, transparent); }
.heat.heat--l4     { fill: var(--ink); }
.heat.heat--skip   { fill: color-mix(in srgb, var(--accent-work) 30%, transparent); }

.heatmap-legend {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--serif);
    font-style: italic;
    font-size: 12px;
    color: var(--ink-mute);
    flex-wrap: wrap;
    margin: 0;
}
.legend-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 2px;
    vertical-align: middle;
    margin: 0 2px;
}

/* --- Familie / Household --- */

.household {
    background: var(--card);
    border: 1px solid var(--card-line);
    border-radius: var(--radius);
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.household__head { display: flex; flex-direction: column; gap: 4px; }
.household__title {
    font-family: var(--serif);
    font-size: 20px;
    color: var(--ink);
    margin: 0;
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.household__meta { margin: 0; color: var(--ink-mute); font-size: 13px; }

.code {
    font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
    background: color-mix(in srgb, var(--paper-line) 100%, transparent);
    padding: 2px 8px;
    border-radius: 4px;
    letter-spacing: 0.03em;
    color: var(--ink);
    font-size: 14px;
}

.member-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    border-top: 1px solid var(--card-line);
    padding-top: 12px;
}
.member {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 8px 0;
    color: var(--ink);
}
.member .hint { font-size: 13px; color: var(--ink-mute); }

/* --- Insights --- */

.motivation { text-align: center; }
.motivation__value {
    font-family: var(--serif);
    font-size: 48px;
    line-height: 1.05;
    margin: 4px 0 6px;
    color: var(--ink);
    display: flex; align-items: center; justify-content: center; gap: 10px;
}
.motivation__arrow { font-size: 32px; }
.motivation__meta { color: var(--ink-mute); font-size: 13px; margin: 0; }

.trend--up      { color: var(--success); }
.trend--down    { color: var(--danger); }
.trend--steady  { color: var(--ink-mute); }

.trend-badge {
    display: inline-block;
    font-size: 12px;
    padding: 2px 8px;
    border-radius: 999px;
    border: 1px solid currentColor;
    letter-spacing: 0.02em;
}

.corr-list {
    list-style: none;
    margin: 8px 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.corr-list li {
    padding: 10px 12px;
    background: color-mix(in srgb, var(--paper-line) 60%, transparent);
    border-radius: 8px;
    line-height: 1.4;
}

.insights-card {
    background: var(--card);
    border: 1px solid var(--card-line);
    border-radius: var(--radius);
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.insight-block {}

.weekday-bars {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    align-items: end;
    gap: 6px;
    height: 96px;
}
.weekday {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    height: 100%;
    justify-content: flex-end;
}
.weekday__bar {
    width: 100%;
    background: var(--ink);
    border-radius: 4px 4px 0 0;
    min-height: 3px;
}
.weekday__label {
    font-family: var(--serif);
    font-style: italic;
    color: var(--ink-mute);
    font-size: 12px;
}

/* --- Monatsrad --- */

.wheel-wrap {
    display: flex;
    justify-content: center;
    padding: 8px 0;
    overflow-x: auto;
}
.wheel {
    width: min(100%, 560px);
    height: auto;
    display: block;
}
.wheel__day {
    font-family: var(--serif);
    fill: var(--ink-mute);
    font-size: 14px;
    font-style: italic;
}
.wheel__day--today {
    fill: var(--ink);
    font-weight: 500;
    font-style: normal;
}

.wheel-legend {
    list-style: none;
    margin: 8px 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.wheel-legend__item {
    display: flex;
    gap: 12px;
    align-items: flex-start;
}
.wheel-legend__item--muted { opacity: 0.55; }
.wheel-legend__dot {
    display: inline-block;
    width: 14px;
    height: 14px;
    border-radius: 999px;
    flex-shrink: 0;
    margin-top: 4px;
}
.wheel-legend__body {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px 8px;
    min-width: 0;
}
.wheel-legend__body .hint { flex-basis: 100%; }

/* --- Flashes --- */

.flash {
    padding: 12px 14px;
    border-radius: 10px;
    border: 1px solid var(--card-line);
    background: var(--card);
    font-size: 15px;
}
.flash-error   { border-color: var(--danger);  color: var(--danger); }
.flash-success { border-color: var(--success); color: var(--success); }
.flash-info    { color: var(--ink-mute); }

@media (min-width: 720px) {
    .shell { padding: 40px var(--shell-pad); }
    .display { font-size: 40px; }
}

/* --- Heute: Tages-Übersicht --- */

.today-summary {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px 18px;
    background: var(--card);
    border: 1px solid var(--card-line);
    border-radius: var(--radius);
}
.today-summary--all-done { border-color: color-mix(in srgb, var(--success) 55%, var(--card-line)); }

.summary-ring { flex-shrink: 0; width: 56px; height: 56px; }
.summary-ring__track { stroke: color-mix(in srgb, var(--paper-line) 100%, transparent); }
.summary-ring__value {
    stroke: var(--ink);
    stroke-linecap: round;
    transition: stroke-dashoffset 360ms ease;
    transform: rotate(-90deg);
    transform-origin: center;
}
.today-summary--all-done .summary-ring__value { stroke: var(--success); }
.summary-ring__text {
    font-family: var(--serif);
    font-size: 15px;
    fill: var(--ink);
    dominant-baseline: central;
    text-anchor: middle;
}

.today-summary__body { min-width: 0; }
.today-summary__headline {
    font-family: var(--serif);
    font-size: 18px;
    color: var(--ink);
    margin: 0 0 2px;
    line-height: 1.2;
}
.today-summary__meta { font-size: 13px; color: var(--ink-mute); margin: 0; }

/* --- Hinweis / Tipp --- */
.tip {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: color-mix(in srgb, var(--paper-line) 70%, transparent);
    border: 1px dashed var(--card-line);
    border-radius: var(--radius);
}
.tip__text { margin: 0; font-size: 14px; color: var(--ink-mute); line-height: 1.45; }
.tip__dots {
    font-weight: 700;
    color: var(--ink);
    padding: 0 4px;
}
.tip__close {
    flex-shrink: 0;
    background: transparent;
    color: var(--ink-mute);
    border: 1px solid var(--card-line);
    padding: 6px 12px;
    min-height: 40px;
    border-radius: 8px;
    font-size: 13px;
    font-family: var(--sans);
}
.tip__close:hover { color: var(--ink); background: var(--card); }

/* --- Installations-Banner (PWA) --- */
.install-banner {
    position: fixed;
    left: 12px;
    right: 12px;
    bottom: calc(72px + env(safe-area-inset-bottom));
    max-width: 536px;
    margin: 0 auto;
    z-index: 40;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: var(--card);
    border: 1px solid var(--card-line);
    border-radius: var(--radius);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.16);
}
.install-banner__text { margin: 0; flex: 1 1 auto; font-size: 14px; color: var(--ink); line-height: 1.4; }
.install-banner__actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.install-banner__cta {
    background: var(--ink);
    color: var(--paper);
    border: 0;
    border-radius: 10px;
    padding: 10px 16px;
    min-height: 44px;
    font-size: 14px;
}
.install-banner__close {
    background: transparent;
    color: var(--ink-mute);
    border: 1px solid var(--card-line);
    border-radius: 10px;
    padding: 10px 12px;
    min-height: 44px;
    font-size: 13px;
}
.install-banner__close:hover { color: var(--ink); }
@media (max-width: 400px) {
    .install-banner { flex-direction: column; align-items: stretch; }
    .install-banner__actions { justify-content: flex-end; }
}
@media (prefers-reduced-motion: no-preference) {
    .install-banner { animation: install-in 220ms ease-out; }
    @keyframes install-in {
        from { opacity: 0; transform: translateY(8px); }
        to   { opacity: 1; transform: translateY(0); }
    }
}

/* --- Rückblick: Subnavigation --- */

.review-subnav {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.review-subnav__views { justify-content: flex-start; }
.review-subnav__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}
.review-subnav__row .chip-row { flex: 1 1 auto; }

/* --- Kopier-Button (Familie) --- */

.copy-inline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.copy-btn {
    background: transparent;
    color: var(--ink-mute);
    border: 1px solid var(--card-line);
    padding: 4px 10px;
    min-height: 32px;
    border-radius: 8px;
    font-size: 13px;
    font-family: var(--sans);
}
.copy-btn:hover { color: var(--ink); background: var(--card); }
.copy-btn--ok { color: var(--success); border-color: var(--success); }

/* --- Toast --- */

.toast-host {
    position: fixed;
    left: 50%;
    bottom: calc(84px + env(safe-area-inset-bottom));
    transform: translateX(-50%);
    z-index: 50;
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: max-content;
    max-width: min(92vw, 420px);
    pointer-events: none;
}
.toast {
    padding: 10px 16px;
    border-radius: 999px;
    background: var(--ink);
    color: var(--paper);
    font-size: 14px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.14);
    text-align: center;
}
.toast--error { background: var(--danger); color: #fff; }

@media (prefers-reduced-motion: no-preference) {
    .toast { animation: toast-in 160ms ease; }
}
@keyframes toast-in {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Kurzer Bestätigungs-Puls nach erfolgreichem Ein-Tap-Log */
@media (prefers-reduced-motion: no-preference) {
    .today-card--just-logged { animation: card-pulse 420ms ease; }
}
@keyframes card-pulse {
    0%   { box-shadow: 0 0 0 0 color-mix(in srgb, var(--success) 45%, transparent); }
    100% { box-shadow: 0 0 0 10px transparent; }
}

/* =========================================================
   Landing / Produktseite (nur für Gäste)
   ========================================================= */

.landing { display: flex; flex-direction: column; gap: 56px; }
.landing section { scroll-margin-top: 24px; }

/* --- Hero --- */

.hero { display: flex; flex-direction: column; gap: 20px; }
.hero__brand {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--serif);
    font-style: italic;
    color: var(--ink-mute);
    font-size: 15px;
}
.hero__brand .brand-dot {
    width: 10px; height: 10px; border-radius: 999px;
    background: var(--accent-private);
    display: inline-block;
}
.hero__title { font-size: 34px; }
.hero__lede { font-size: 18px; max-width: 46ch; }

.hero__art {
    align-self: center;
    width: min(280px, 78%);
    height: auto;
    margin: 4px 0;
}

.cta-group {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 14px;
}
.btn--lg { padding: 14px 24px; font-size: 17px; }

.pill-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    margin: 0;
    padding: 0;
    list-style: none;
}
.pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--ink-mute);
    font-size: 14px;
}
.pill .ico { color: var(--success); }

/* --- Generisches Icon --- */

.ico { width: 22px; height: 22px; flex-shrink: 0; display: block; }
.ico--lg { width: 26px; height: 26px; }

/* --- Section-Kopf --- */

.section-head { display: flex; flex-direction: column; gap: 6px; margin-bottom: 20px; }
.section-head .eyebrow { margin: 0; }
.section-head h2 {
    font-family: var(--serif);
    font-weight: 500;
    font-size: 26px;
    line-height: 1.15;
    color: var(--ink);
    margin: 0;
    letter-spacing: -0.01em;
}

/* --- Werte-Grid --- */

.value-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}
@media (min-width: 480px) {
    .value-grid { grid-template-columns: 1fr 1fr; }
}
.value {
    background: var(--card);
    border: 1px solid var(--card-line);
    border-radius: var(--radius);
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.value__ico {
    width: 40px; height: 40px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 10px;
    background: color-mix(in srgb, var(--paper-line) 90%, transparent);
    color: var(--ink);
}
.value h3 { font-family: var(--serif); font-size: 17px; margin: 0; color: var(--ink); }
.value p { margin: 0; color: var(--ink-mute); font-size: 15px; line-height: 1.5; }

/* --- Feature-Blöcke --- */

.feature-list { display: flex; flex-direction: column; gap: 28px; }
.feature {
    display: grid;
    grid-template-columns: 44px 1fr;
    gap: 16px;
    align-items: start;
}
.feature__ico {
    width: 44px; height: 44px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 12px;
    border: 1px solid var(--card-line);
    background: var(--card);
    color: var(--ink);
}
.feature__title { font-family: var(--serif); font-size: 19px; margin: 0 0 4px; color: var(--ink); }
.feature__text { margin: 0; color: var(--ink-mute); line-height: 1.55; }
.feature__meta {
    display: flex; flex-wrap: wrap; gap: 6px;
    margin-top: 10px;
}
.tag {
    display: inline-block;
    font-size: 12px;
    padding: 3px 10px;
    border-radius: 999px;
    border: 1px solid var(--card-line);
    color: var(--ink-mute);
    background: var(--card);
    letter-spacing: 0.02em;
}

/* --- Schritte --- */

.steps {
    counter-reset: step;
    list-style: none;
    margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: 14px;
}
.steps li {
    display: grid;
    grid-template-columns: 40px 1fr;
    gap: 14px;
    align-items: start;
}
.steps li::before {
    counter-increment: step;
    content: counter(step);
    width: 40px; height: 40px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 999px;
    background: var(--ink);
    color: var(--paper);
    font-family: var(--serif);
    font-size: 18px;
}
.steps h3 { font-family: var(--serif); font-size: 17px; margin: 0 0 2px; color: var(--ink); }
.steps p { margin: 0; color: var(--ink-mute); font-size: 15px; }

/* Kompakte Steps innerhalb einer Karte (z. B. Telegram-Anleitung) */
.steps--compact { gap: 12px; }
.steps--compact li { grid-template-columns: 30px 1fr; gap: 12px; }
.steps--compact li::before { width: 30px; height: 30px; font-size: 15px; }
.steps--compact h3 { font-size: 16px; }
.steps--compact p { font-size: 14px; }

/* Live-Indikator: Seite prüft die Verknüpfung automatisch */
.tg-live { display: inline-flex; align-items: center; gap: 7px; }
.tg-live::before {
    content: "";
    width: 8px; height: 8px;
    border-radius: 999px;
    background: var(--success);
    animation: tg-pulse 1.6s ease-out infinite;
}
@keyframes tg-pulse {
    0%   { box-shadow: 0 0 0 0 color-mix(in srgb, var(--success) 55%, transparent); }
    70%  { box-shadow: 0 0 0 7px color-mix(in srgb, var(--success) 0%, transparent); }
    100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--success) 0%, transparent); }
}
@media (prefers-reduced-motion: reduce) {
    .tg-live::before { animation: none; }
}

/* --- Zitat / Philosophie --- */

.quote {
    border-left: 3px solid var(--accent-private);
    padding: 4px 0 4px 18px;
    margin: 0;
}
.quote p {
    font-family: var(--serif);
    font-style: italic;
    font-size: 22px;
    line-height: 1.35;
    color: var(--ink);
    margin: 0;
}
.quote cite { display: block; margin-top: 8px; font-style: normal; color: var(--ink-mute); font-size: 14px; }

/* --- FAQ (native <details>, funktioniert ohne JS) --- */

.faq { display: flex; flex-direction: column; gap: 10px; }
.faq details {
    background: var(--card);
    border: 1px solid var(--card-line);
    border-radius: var(--radius);
    padding: 4px 16px;
}
.faq summary {
    cursor: pointer;
    list-style: none;
    padding: 12px 0;
    font-family: var(--serif);
    font-size: 17px;
    color: var(--ink);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
    content: '+';
    font-family: var(--sans);
    color: var(--ink-mute);
    font-size: 22px;
    line-height: 1;
    transition: transform 160ms ease;
}
.faq details[open] summary::after { content: '−'; }
.faq details p { margin: 0 0 14px; color: var(--ink-mute); line-height: 1.55; }

/* --- Abschluss-CTA --- */

.cta-card {
    background: var(--card);
    border: 1px solid var(--card-line);
    border-radius: var(--radius);
    padding: 28px 22px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
}
.cta-card h2 {
    font-family: var(--serif);
    font-weight: 500;
    font-size: 26px;
    margin: 0;
    color: var(--ink);
}
.cta-card p { margin: 0; color: var(--ink-mute); max-width: 40ch; }

/* --- Footer --- */

.landing-footer {
    border-top: 1px solid var(--card-line);
    padding-top: 20px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: var(--ink-faint);
    font-size: 14px;
}
.landing-footer nav { display: flex; gap: 16px; flex-wrap: wrap; }

@media (min-width: 720px) {
    .hero__title { font-size: 42px; }
    .landing { gap: 72px; }
}
