/* =========================================================================
   PUNKTESYSTEM — Modern Dark Dashboard with Lavender accent
   ========================================================================= */

:root {
    /* Surfaces */
    --bg:           #0d0e12;
    --bg-soft:      #14161c;
    --bg-elev:      #1c1f27;
    --bg-strong:    #232732;
    --bg-input:     #1a1d24;

    /* Text */
    --fg:           #e8e9ee;
    --fg-soft:      #a4a8b6;
    --fg-faded:     #6c7080;
    --fg-dim:       #4a4d59;

    /* Lines / borders */
    --line:         #262934;
    --line-soft:    #1c1e25;
    --line-strong:  #2f3340;

    /* Lavender accent system */
    --accent:        #b794f6;
    --accent-soft:   #c9b1ff;
    --accent-deep:   #8362cf;
    --accent-dark:   #5d3fa3;
    --accent-tint:   rgba(183, 148, 246, 0.12);
    --accent-tint-2: rgba(183, 148, 246, 0.20);
    --accent-glow:   rgba(183, 148, 246, 0.35);

    /* States */
    --success:       #6ec8a8;
    --success-tint:  rgba(110, 200, 168, 0.14);
    --warn:          #e3c46d;
    --warn-tint:     rgba(227, 196, 109, 0.14);
    --danger:        #e08379;
    --danger-tint:   rgba(224, 131, 121, 0.14);
    --info:          #7eb6f0;

    /* Type */
    --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI Variable", "Segoe UI",
                 system-ui, "Helvetica Neue", Arial, sans-serif;
    --font-mono: ui-monospace, "Cascadia Mono", "SF Mono", Menlo, Consolas, monospace;

    /* Radii */
    --r-xs: 4px;
    --r-sm: 6px;
    --r-md: 10px;
    --r-lg: 14px;
    --r-xl: 20px;

    /* Shadows */
    --shadow-1: 0 1px 2px rgba(0, 0, 0, 0.4);
    --shadow-2: 0 4px 16px rgba(0, 0, 0, 0.4);
    --shadow-3: 0 8px 32px rgba(0, 0, 0, 0.5), 0 2px 8px rgba(0, 0, 0, 0.4);
    --shadow-accent: 0 0 0 1px var(--accent-tint-2), 0 8px 24px -8px var(--accent-glow);

    color-scheme: dark;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
    background: var(--bg);
    color: var(--fg);
    font-family: var(--font-sans);
    font-size: 15px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    min-height: 100vh;
    min-height: 100dvh;
    overflow-x: hidden;
    letter-spacing: -0.005em;
}

button {
    font: inherit;
    color: inherit;
    background: none;
    border: 0;
    cursor: pointer;
    padding: 0;
    letter-spacing: inherit;
}
input, textarea, select {
    font: inherit;
    color: inherit;
    letter-spacing: inherit;
}
a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-soft); }

::selection { background: var(--accent-tint-2); color: var(--fg); }

/* Subtle ambient gradient on body */
body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 12% -10%, rgba(183, 148, 246, 0.10), transparent 50%),
        radial-gradient(circle at 92% 110%, rgba(126, 182, 240, 0.06), transparent 55%);
    z-index: 0;
}
body > * { position: relative; z-index: 1; }

/* ---------- View switching ---------- */
.view { display: none; }
.view.active { display: block; }

/* ---------- Splash ---------- */
#view-splash { min-height: 100dvh; display: none; align-items: center; justify-content: center; }
#view-splash.active { display: flex; }
.splash-inner { text-align: center; }
.splash-logo {
    font-size: 72px;
    font-weight: 700;
    color: var(--accent);
    letter-spacing: -0.04em;
    line-height: 1;
    text-shadow: 0 0 40px var(--accent-glow);
}
.splash-tag {
    margin-top: 1.4em;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--fg-faded);
}

/* ---------- Forms (login / setup) ---------- */
.form-shell {
    max-width: 460px;
    margin: 0 auto;
    padding: clamp(56px, 12vw, 140px) clamp(24px, 5vw, 40px) 80px;
}
.form-eyebrow {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 20px;
}
.display {
    font-size: clamp(36px, 6vw, 52px);
    font-weight: 600;
    line-height: 1.05;
    letter-spacing: -0.03em;
    margin: 0 0 16px;
    color: var(--fg);
}
.lead {
    font-size: 16px;
    color: var(--fg-soft);
    margin: 0 0 40px;
    max-width: 40ch;
    line-height: 1.55;
}
.stacked-form {
    display: grid;
    gap: 18px;
}
.stacked-form label {
    display: grid;
    gap: 8px;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--fg-faded);
}
.stacked-form label small {
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
    color: var(--fg-dim);
}
.stacked-form input[type=text],
.stacked-form input[type=password],
.stacked-form input:not([type]),
.stacked-form input[type=number],
.stacked-form select,
.stacked-form textarea {
    background: var(--bg-input);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    padding: 12px 14px;
    font-size: 15px;
    color: var(--fg);
    text-transform: none;
    letter-spacing: 0;
    transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
    font-family: inherit;
}
.stacked-form input:focus,
.stacked-form select:focus,
.stacked-form textarea:focus {
    outline: none;
    border-color: var(--accent-deep);
    box-shadow: 0 0 0 3px var(--accent-tint);
}
.stacked-form label.row {
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 14px;
}
.stacked-form label.row > span {
    color: var(--fg-faded);
}
.stacked-form label.row input { max-width: 110px; text-align: right; }
.stacked-form label.checkbox {
    grid-template-columns: auto 1fr;
    align-items: start;
    text-transform: none;
    letter-spacing: 0;
    font-size: 14px;
    color: var(--fg-soft);
    gap: 12px;
    cursor: pointer;
}
.stacked-form label.checkbox input[type=checkbox] {
    appearance: none;
    width: 20px; height: 20px;
    border: 1.5px solid var(--line-strong);
    border-radius: var(--r-xs);
    background: var(--bg-input);
    cursor: pointer;
    transition: all 0.15s;
    margin: 1px 0 0;
    flex-shrink: 0;
    position: relative;
}
.stacked-form label.checkbox input[type=checkbox]:checked {
    background: var(--accent);
    border-color: var(--accent);
}
.stacked-form label.checkbox input[type=checkbox]:checked::after {
    content: "";
    position: absolute;
    left: 5px; top: 1px;
    width: 6px; height: 11px;
    border: solid var(--bg);
    border-width: 0 2.5px 2.5px 0;
    transform: rotate(45deg);
}
.hint-inline {
    color: var(--fg-faded);
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
    line-height: 1.5;
    margin-top: 4px;
}

.btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: var(--accent);
    color: #110a1f;
    font-weight: 600;
    font-size: 14px;
    padding: 12px 22px;
    border-radius: var(--r-md);
    cursor: pointer;
    transition: transform 0.1s, box-shadow 0.2s, background 0.2s;
    box-shadow: 0 0 0 1px transparent, 0 4px 14px -4px var(--accent-glow);
    letter-spacing: -0.01em;
}
.btn-primary:hover {
    background: var(--accent-soft);
    box-shadow: 0 0 0 1px var(--accent-tint-2), 0 8px 24px -6px var(--accent-glow);
    transform: translateY(-1px);
}
.btn-primary:active { transform: translateY(0); }
.btn-primary.inline { padding: 9px 16px; font-size: 13px; }
.btn-primary .arrow {
    font-size: 16px;
    line-height: 1;
    transition: transform 0.2s;
}
.btn-primary:hover .arrow { transform: translateX(3px); }

.link-btn {
    color: var(--fg-soft);
    font-size: 13px;
    font-weight: 500;
    padding: 6px 8px;
    border-radius: var(--r-sm);
    transition: color 0.15s, background 0.15s;
}
.link-btn:hover { color: var(--fg); background: var(--bg-elev); }
.link-btn.danger { color: var(--danger); }
.link-btn.danger:hover { color: var(--danger); background: var(--danger-tint); }

.form-msg {
    margin: 4px 0 0;
    font-size: 13px;
    color: var(--danger);
    letter-spacing: 0;
    text-transform: none;
    font-weight: 400;
}
.form-msg.success { color: var(--success); }

/* ---------- App shell ---------- */
.topbar {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 16px;
    padding: 16px clamp(20px, 4vw, 40px);
    border-bottom: 1px solid var(--line);
    background: rgba(13, 14, 18, 0.7);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    position: sticky;
    top: 0;
    z-index: 30;
}
.brand {
    display: flex; align-items: center; gap: 10px;
}
.brand-mark {
    display: inline-flex;
    align-items: center; justify-content: center;
    width: 30px; height: 30px;
    border-radius: var(--r-sm);
    background: var(--accent-tint);
    color: var(--accent);
    font-weight: 700;
    font-size: 16px;
    letter-spacing: -0.02em;
}
.brand-text {
    font-weight: 600;
    font-size: 15px;
    color: var(--fg);
    letter-spacing: -0.01em;
}
.tabs {
    display: flex;
    gap: 2px;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    padding: 4px;
    border-radius: var(--r-lg);
}
.tab {
    font-size: 13px;
    font-weight: 500;
    padding: 8px 16px;
    border-radius: var(--r-md);
    color: var(--fg-soft);
    transition: color 0.15s, background 0.15s;
    letter-spacing: -0.01em;
}
.tab[aria-current="true"] {
    background: var(--bg-elev);
    color: var(--fg);
    box-shadow: var(--shadow-1);
}
.tab:hover:not([aria-current="true"]) {
    color: var(--fg);
}
.user {
    justify-self: end;
    display: flex; align-items: center; gap: 8px;
    font-size: 13px;
    color: var(--fg-faded);
}
.user-name { color: var(--fg-soft); font-weight: 500; }

/* ---------- Tab panels ---------- */
.tab-panel {
    padding: clamp(28px, 4vw, 56px) clamp(20px, 4vw, 48px) 96px;
    max-width: 1280px;
    margin: 0 auto;
}
.section-title {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.04em;
    color: var(--fg-faded);
    text-transform: uppercase;
    margin: 0 0 16px;
}
.section-title small {
    font-weight: 400;
    font-size: 12px;
    letter-spacing: 0;
    text-transform: none;
    color: var(--fg-dim);
    margin-left: 8px;
}

/* ---------- Week head ---------- */
.week-head {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: end;
    gap: 32px;
    margin-bottom: 28px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--line);
}

.week-nav {
    display: flex; align-items: center;
    gap: clamp(8px, 2vw, 16px);
    flex-wrap: wrap;
}
.nav-arrow {
    width: 38px; height: 38px;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    font-size: 18px;
    color: var(--fg-soft);
    line-height: 1;
    display: inline-flex; align-items: center; justify-content: center;
    transition: all 0.15s;
}
.nav-arrow:hover {
    background: var(--bg-elev);
    border-color: var(--line-strong);
    color: var(--fg);
}
.week-label {
    display: grid;
    line-height: 1.1;
}
.week-kw {
    font-size: clamp(28px, 4vw, 36px);
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--fg);
}
.week-range {
    font-size: 13px;
    color: var(--fg-faded);
    margin-top: 4px;
    font-variant-numeric: tabular-nums;
}
.nav-today { align-self: center; }

.score {
    text-align: right;
    min-width: 220px;
}
.score-number {
    font-weight: 600;
    line-height: 0.95;
    display: flex; align-items: baseline; justify-content: flex-end;
    gap: 4px;
    letter-spacing: -0.04em;
}
.score-current {
    font-size: clamp(48px, 8vw, 72px);
    color: var(--fg);
    font-variant-numeric: tabular-nums;
    transition: color 0.3s;
}
.score-current.success { color: var(--success); }
.score-current.fail    { color: var(--danger); }
.score-divider { font-size: 24px; color: var(--fg-dim); font-weight: 400; }
.score-goal {
    font-size: 22px;
    color: var(--fg-faded);
    font-variant-numeric: tabular-nums;
    font-weight: 500;
}
.score-bar {
    margin-top: 12px;
    height: 6px;
    border-radius: 999px;
    background: var(--bg-soft);
    overflow: hidden;
    border: 1px solid var(--line-soft);
}
.score-bar-fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--accent) 0%, var(--success) 100%);
    border-radius: inherit;
    transition: width 0.5s cubic-bezier(.2,.8,.2,1);
    box-shadow: 0 0 12px var(--accent-glow);
}
.score-meta {
    margin-top: 10px;
    font-size: 12px;
    color: var(--fg-faded);
    letter-spacing: 0.01em;
}

/* ---------- Week grid ---------- */
.grid-wrap {
    margin: 0 calc(-1 * clamp(20px, 4vw, 48px));
    padding: 0 clamp(20px, 4vw, 48px);
    overflow-x: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--line-strong) transparent;
}
.week-grid {
    width: 100%;
    min-width: 820px;
    border-collapse: separate;
    border-spacing: 0;
}
.week-grid thead th {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fg-faded);
    padding: 8px 0 14px;
    text-align: center;
    border-bottom: 1px solid var(--line);
}
.week-grid thead th.col-name { text-align: left; padding-left: 4px; min-width: 220px; }
.week-grid thead th.col-meta { text-align: left; padding-left: 12px; min-width: 92px; }
.week-grid thead th.col-sum { color: var(--accent); }

.week-grid tbody tr { transition: background 0.15s; }
.week-grid tbody tr:hover { background: var(--bg-soft); }
.week-grid tbody td {
    padding: 12px 4px;
    text-align: center;
    border-bottom: 1px solid var(--line-soft);
    vertical-align: middle;
}
.week-grid tbody td.cell-name {
    text-align: left;
    padding-left: 4px;
    font-size: 14px;
    color: var(--fg);
    cursor: pointer;
    font-weight: 500;
}
.week-grid tbody td.cell-name:hover { color: var(--accent); }
.week-grid tbody td.cell-meta {
    text-align: left;
    padding-left: 12px;
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--fg-faded);
    white-space: nowrap;
}
.week-grid tbody td.cell-meta .neg-tag {
    color: var(--danger);
    margin-left: 6px;
    padding: 1px 5px;
    background: var(--danger-tint);
    border-radius: var(--r-xs);
    font-family: var(--font-sans);
    font-size: 10px;
    font-weight: 500;
}
.week-grid tbody td.cell-sum {
    font-family: var(--font-mono);
    font-weight: 600;
    font-size: 15px;
    color: var(--fg);
    text-align: right;
    padding-right: 12px;
    width: 60px;
    font-variant-numeric: tabular-nums;
}
.week-grid tbody td.cell-sum.success { color: var(--success); }
.week-grid tbody td.cell-sum.fail    { color: var(--danger); }

.day-cell {
    width: 44px;
    height: 44px;
    border-radius: var(--r-md);
    margin: 0 auto;
    display: inline-flex; align-items: center; justify-content: center;
    font-family: var(--font-mono);
    font-size: 13px;
    font-weight: 500;
    color: var(--fg-faded);
    background: var(--bg-soft);
    border: 1px solid var(--line);
    cursor: pointer;
    transition: all 0.15s;
    user-select: none;
    -webkit-tap-highlight-color: transparent;
    font-variant-numeric: tabular-nums;
}
.day-cell:hover {
    border-color: var(--accent-deep);
    color: var(--fg);
    transform: translateY(-1px);
    box-shadow: var(--shadow-1);
}
.day-cell:active { transform: scale(0.96); }
.day-cell .dot {
    width: 4px; height: 4px;
    border-radius: 50%;
    background: var(--fg-dim);
}
.day-cell.filled {
    background: var(--accent-tint);
    color: var(--accent-soft);
    border-color: var(--accent-deep);
}
.day-cell.over-target {
    background: var(--accent);
    color: #110a1f;
    border-color: var(--accent);
    box-shadow: 0 0 14px -4px var(--accent-glow);
}
.day-cell.fail {
    background: var(--danger-tint);
    color: var(--danger);
    border-color: rgba(224, 131, 121, 0.4);
}
.day-cell.today {
    box-shadow: 0 0 0 2px var(--bg), 0 0 0 3.5px var(--accent);
}
.day-cell.today.filled {
    box-shadow: 0 0 0 2px var(--bg), 0 0 0 3.5px var(--accent-soft);
}

.hint {
    margin-top: 24px;
    font-size: 12px;
    color: var(--fg-faded);
    text-align: center;
}
.kbd {
    font-family: var(--font-mono);
    font-size: 11px;
    padding: 2px 6px;
    background: var(--bg-strong);
    border: 1px solid var(--line);
    border-radius: var(--r-xs);
    color: var(--fg-soft);
}

/* ---------- Stats ---------- */
.stats-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    margin-bottom: 36px;
}
.stat-card {
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    padding: 20px 22px;
    position: relative;
    overflow: hidden;
    transition: border-color 0.2s, transform 0.15s;
}
.stat-card:hover {
    border-color: var(--accent-deep);
    transform: translateY(-2px);
}
.stat-card::after {
    content: "";
    position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg, var(--accent), transparent 80%);
    opacity: 0.7;
}
.stat-num {
    font-weight: 600;
    font-size: 44px;
    line-height: 1;
    color: var(--fg);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.03em;
}
.stat-cap {
    margin-top: 10px;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--fg-soft);
}
.stat-cap small {
    display: block;
    margin-top: 4px;
    font-size: 11px;
    letter-spacing: 0;
    text-transform: none;
    color: var(--fg-faded);
    font-weight: 400;
}

.chart-wrap {
    margin-bottom: 36px;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    padding: 20px;
}

.bar-chart {
    display: flex;
    align-items: flex-end;
    gap: 6px;
    height: 200px;
    padding: 24px 4px 4px;
    position: relative;
    overflow-x: auto;
}
.bar-col {
    flex: 1 1 auto;
    min-width: 26px;
    display: flex; flex-direction: column; align-items: center;
    gap: 8px;
    position: relative;
}
.bar-shape {
    width: 100%;
    background: var(--accent-tint-2);
    border: 1px solid var(--accent-tint-2);
    border-radius: var(--r-sm) var(--r-sm) 2px 2px;
    transition: height 0.6s cubic-bezier(.2,.8,.2,1);
    min-height: 4px;
}
.bar-shape.reached {
    background: var(--accent);
    border-color: var(--accent);
    box-shadow: 0 0 12px -4px var(--accent-glow);
}
.bar-shape.partial { background: var(--accent-tint-2); }
.bar-shape.is-negative { background: var(--danger-tint); border-color: rgba(224, 131, 121, 0.4); }
.bar-label {
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--fg-faded);
}
.bar-val {
    position: absolute;
    top: 0;
    font-size: 12px;
    color: var(--fg-soft);
    font-weight: 500;
    font-variant-numeric: tabular-nums;
}
.bar-col.is-current .bar-label { color: var(--accent); font-weight: 600; }
.bar-col.is-current .bar-val   { color: var(--accent); }

.dow-chart {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 8px;
}
.dow-cell {
    aspect-ratio: 1 / 1;
    border-radius: var(--r-md);
    background: var(--bg);
    border: 1px solid var(--line);
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    position: relative;
    overflow: hidden;
}
.dow-cell .dow-fill {
    position: absolute;
    left: 0; right: 0; bottom: 0;
    background: var(--accent-tint-2);
    transition: height 0.5s;
}
.dow-cell .dow-name {
    font-size: 11px;
    font-weight: 600;
    color: var(--fg-faded);
    position: relative;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 4px;
}
.dow-cell .dow-val {
    font-family: var(--font-mono);
    font-size: 16px;
    color: var(--fg);
    position: relative;
    font-variant-numeric: tabular-nums;
    font-weight: 500;
}

.ranking {
    list-style: none;
    margin: 0; padding: 0;
    display: grid; gap: 6px;
}
.ranking li {
    display: grid;
    grid-template-columns: 28px 1fr auto;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
}
.ranking li .rank {
    font-family: var(--font-mono);
    font-weight: 600;
    font-size: 14px;
    color: var(--accent);
    font-variant-numeric: tabular-nums;
}
.ranking li .r-name { font-size: 14px; color: var(--fg); }
.ranking li .r-num {
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--fg-faded);
    font-variant-numeric: tabular-nums;
}

/* ---------- Habits list ---------- */
.habits-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
}
.habits-list {
    list-style: none;
    margin: 0; padding: 0;
    display: grid; gap: 6px;
}
.habits-list li {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: 16px;
    padding: 14px 18px;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    transition: all 0.15s;
    cursor: pointer;
}
.habits-list li:hover {
    border-color: var(--line-strong);
    background: var(--bg-elev);
    transform: translateY(-1px);
}
.habits-list li .h-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--fg);
}
.habits-list li .h-meta {
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--fg-faded);
    white-space: nowrap;
}
.habits-list li .h-edit {
    font-size: 11px;
    color: var(--fg-faded);
    opacity: 0;
    transition: opacity 0.15s;
}
.habits-list li:hover .h-edit { opacity: 1; }
.habits-list li.neg .h-name::after {
    content: "± neg";
    margin-left: 10px;
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--danger);
    background: var(--danger-tint);
    padding: 2px 6px;
    border-radius: var(--r-xs);
    font-weight: 500;
}

/* ---------- To-Dos ---------- */
.todos-head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 20px;
    gap: 16px;
    flex-wrap: wrap;
}
.todos-head .section-title { margin: 0; }
.todos-filter {
    display: inline-flex;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    padding: 3px;
    gap: 2px;
}
.filter-pill {
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 500;
    color: var(--fg-faded);
    border-radius: var(--r-sm);
    transition: color 0.15s, background 0.15s;
}
.filter-pill[aria-current="true"] {
    background: var(--bg-elev);
    color: var(--fg);
}
.filter-pill:hover:not([aria-current="true"]) { color: var(--fg); }

.group-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--line);
}
.group-chip {
    display: inline-flex;
    align-items: stretch;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: 999px;
    transition: border-color 0.15s, background 0.15s;
    overflow: hidden;
}
.group-chip:hover { border-color: var(--line-strong); }
.group-chip.active {
    background: var(--accent-tint);
    border-color: var(--accent-deep);
}
.group-chip.add {
    padding: 0;
}
.group-chip.add:hover {
    border-color: var(--accent-deep);
    background: var(--accent-tint);
}
.group-chip.add::before {
    content: "+";
    padding: 8px 14px;
    font-size: 16px;
    line-height: 1;
    color: var(--fg-faded);
}
.group-chip.add:hover::before { color: var(--accent); }

.chip-main {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    font-size: 13px;
    font-weight: 500;
    color: var(--fg-soft);
    cursor: pointer;
    transition: color 0.15s;
}
.chip-main:hover { color: var(--fg); }
.group-chip.active .chip-main { color: var(--accent-soft); }
.chip-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}
.chip-count {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--fg-faded);
    padding: 2px 7px;
    background: var(--bg);
    border-radius: 999px;
    font-variant-numeric: tabular-nums;
    font-weight: 500;
}
.group-chip.active .chip-count {
    background: rgba(0, 0, 0, 0.3);
    color: var(--accent-soft);
}
.chip-edit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 12px;
    color: var(--fg-faded);
    border-left: 1px solid var(--line);
    font-size: 14px;
    line-height: 1;
    letter-spacing: 0.1em;
    cursor: pointer;
    transition: color 0.15s, background 0.15s;
}
.chip-edit:hover {
    color: var(--accent);
    background: var(--bg-elev);
}
.group-chip.active .chip-edit { border-left-color: var(--accent-deep); }

.todo-add {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 8px;
    margin-bottom: 24px;
}
.todo-add input[type=text] {
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    padding: 12px 14px;
    font-size: 14px;
    color: var(--fg);
    font-family: inherit;
    transition: all 0.15s;
}
.todo-add input[type=text]::placeholder { color: var(--fg-dim); }
.todo-add input[type=text]:focus {
    outline: none;
    border-color: var(--accent-deep);
    box-shadow: 0 0 0 3px var(--accent-tint);
    background: var(--bg-elev);
}
.todo-add select {
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    padding: 12px 14px;
    font-size: 13px;
    color: var(--fg-soft);
    font-family: inherit;
    cursor: pointer;
    min-width: 140px;
}
.todo-add select:focus {
    outline: none;
    border-color: var(--accent-deep);
}

.todo-list {
    list-style: none;
    margin: 0; padding: 0;
    display: grid; gap: 4px;
}
.todo-item {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    transition: all 0.15s;
}
.todo-item:hover {
    border-color: var(--line-strong);
    background: var(--bg-elev);
}
.todo-check {
    appearance: none;
    width: 22px; height: 22px;
    border: 1.5px solid var(--line-strong);
    border-radius: 50%;
    background: var(--bg);
    cursor: pointer;
    transition: all 0.15s;
    flex-shrink: 0;
    position: relative;
}
.todo-check:hover { border-color: var(--accent); }
.todo-check:checked {
    background: var(--accent);
    border-color: var(--accent);
}
.todo-check:checked::after {
    content: "";
    position: absolute;
    left: 6px; top: 2px;
    width: 6px; height: 11px;
    border: solid var(--bg);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}
.todo-title {
    font-size: 14px;
    color: var(--fg);
    line-height: 1.4;
    cursor: pointer;
    word-break: break-word;
}
.todo-title:hover { color: var(--accent-soft); }
.todo-item.done .todo-title {
    text-decoration: line-through;
    text-decoration-color: var(--fg-dim);
    color: var(--fg-faded);
}
.todo-group-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 500;
    color: var(--fg-faded);
    padding: 4px 8px;
    background: var(--bg);
    border-radius: var(--r-sm);
    white-space: nowrap;
}
.todo-group-tag .tag-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
}
.todo-del {
    width: 28px; height: 28px;
    color: var(--fg-dim);
    border-radius: var(--r-sm);
    opacity: 0;
    transition: all 0.15s;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 14px;
    line-height: 1;
}
.todo-item:hover .todo-del { opacity: 1; }
.todo-del:hover { color: var(--danger); background: var(--danger-tint); }

.todo-divider {
    margin: 24px 0 12px;
    font-size: 11px;
    color: var(--fg-faded);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-weight: 600;
    display: flex; align-items: center; gap: 12px;
}
.todo-divider::before,
.todo-divider::after {
    content: "";
    flex: 1; height: 1px;
    background: var(--line);
}

.todo-empty {
    padding: 64px 24px;
    text-align: center;
    color: var(--fg-faded);
    font-size: 14px;
    font-style: italic;
}

/* Color picker for groups */
.color-picker {
    display: flex; gap: 8px; flex-wrap: wrap;
    padding: 8px 0;
}
.color-swatch {
    width: 28px; height: 28px;
    border-radius: 50%;
    cursor: pointer;
    border: 2px solid transparent;
    transition: transform 0.1s, border-color 0.15s;
}
.color-swatch:hover { transform: scale(1.08); }
.color-swatch.active {
    border-color: var(--fg);
    box-shadow: 0 0 0 2px var(--bg);
}

/* ---------- Sheet (action sheet) ---------- */
.sheet {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 100;
    display: flex; align-items: flex-end; justify-content: center;
    animation: fade-in 0.2s ease-out;
}
.sheet[hidden] { display: none; }
.sheet-card {
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-bottom: 0;
    border-radius: var(--r-xl) var(--r-xl) 0 0;
    padding: 28px 24px 36px;
    width: 100%;
    max-width: 480px;
    box-shadow: var(--shadow-3);
    animation: slide-up 0.28s cubic-bezier(.2,.8,.2,1);
}
.sheet-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--fg);
    margin-bottom: 6px;
    letter-spacing: -0.01em;
}
.sheet-sub {
    font-size: 13px;
    color: var(--fg-faded);
    margin-bottom: 20px;
}
.sheet-actions {
    display: grid;
    gap: 6px;
    margin-bottom: 12px;
}
.sheet-btn {
    padding: 13px 18px;
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    font-size: 14px;
    color: var(--fg);
    text-align: left;
    transition: all 0.15s;
    font-weight: 500;
}
.sheet-btn:hover {
    background: var(--bg-elev);
    border-color: var(--accent-deep);
}
.sheet-btn.danger { color: var(--danger); border-color: rgba(224, 131, 121, 0.25); }
.sheet-btn.danger:hover { background: var(--danger-tint); border-color: var(--danger); }
.sheet-close {
    width: 100%;
    text-align: center;
    padding: 12px;
    font-size: 13px;
    color: var(--fg-faded);
    border-radius: var(--r-md);
    transition: color 0.15s, background 0.15s;
}
.sheet-close:hover { color: var(--fg); background: var(--bg-elev); }

/* ---------- Modal ---------- */
.modal {
    position: fixed; inset: 0;
    background: rgba(0, 0, 0, 0.65);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    z-index: 100;
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
    animation: fade-in 0.2s ease-out;
}
.modal[hidden] { display: none; }
.modal-card {
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    padding: 32px clamp(24px, 4vw, 36px);
    max-width: 480px;
    width: 100%;
    box-shadow: var(--shadow-3);
    animation: scale-in 0.24s cubic-bezier(.2,.8,.2,1);
}
.modal-title {
    font-size: 20px;
    font-weight: 600;
    color: var(--fg);
    margin: 0 0 24px;
    letter-spacing: -0.02em;
}
.modal-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 12px;
}
.modal-actions .spacer { flex: 1; }

/* ---------- Toast ---------- */
.toast {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--bg-elev);
    border: 1px solid var(--line-strong);
    color: var(--fg);
    font-size: 14px;
    font-weight: 500;
    padding: 12px 20px;
    border-radius: var(--r-md);
    z-index: 200;
    box-shadow: var(--shadow-3);
    animation: toast-in 0.25s cubic-bezier(.2,.8,.2,1);
}
.toast[hidden] { display: none; }
.toast.success { border-color: var(--success); color: var(--success); }
.toast.fail    { border-color: var(--danger);  color: var(--danger);  }

/* ---------- Animations ---------- */
@keyframes fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes slide-up {
    from { transform: translateY(28px); opacity: 0; }
    to   { transform: translateY(0); opacity: 1; }
}
@keyframes scale-in {
    from { transform: scale(0.96); opacity: 0; }
    to   { transform: scale(1); opacity: 1; }
}
@keyframes toast-in {
    from { transform: translate(-50%, 16px); opacity: 0; }
    to   { transform: translate(-50%, 0); opacity: 1; }
}
@keyframes pulse-accent {
    0%   { transform: scale(1); }
    50%  { transform: scale(1.18); box-shadow: 0 0 18px var(--accent-glow); }
    100% { transform: scale(1); }
}
.day-cell.just-clicked { animation: pulse-accent 0.4s ease-out; }

/* ---------- Mobile ---------- */
@media (max-width: 760px) {
    .topbar {
        grid-template-columns: 1fr auto;
        grid-template-rows: auto auto;
        gap: 8px;
        padding: 12px 16px;
    }
    .brand { grid-column: 1; grid-row: 1; }
    .user  { grid-column: 2; grid-row: 1; }
    .tabs  {
        grid-column: 1 / -1; grid-row: 2;
        justify-self: stretch;
        overflow-x: auto;
        scrollbar-width: none;
    }
    .tabs::-webkit-scrollbar { display: none; }
    .tab   { flex: 1 0 auto; text-align: center; padding: 8px 12px; font-size: 12px; }

    .user { gap: 4px; }
    .user-name { display: none; }
    .user .link-btn { padding: 5px 8px; font-size: 12px; }

    .week-head {
        grid-template-columns: 1fr;
        gap: 16px;
        align-items: start;
    }
    .score { text-align: left; }
    .score-number { justify-content: flex-start; }

    .tab-panel { padding: 20px 16px 80px; }

    .stat-num { font-size: 32px; }
    .stat-card { padding: 16px 18px; }
    .modal-title { font-size: 18px; }
    .modal-card { padding: 24px 20px; }

    /* ---------- Wochengrid mobil: Karten statt H-Scroll ---------- */
    .grid-wrap {
        margin: 0;
        padding: 0;
        overflow: visible;
    }
    .week-grid { min-width: 0; width: 100%; }
    .week-grid, .week-grid thead, .week-grid tbody, .week-grid tr, .week-grid td {
        display: block;
    }
    .week-grid thead { display: none; }

    .week-grid tbody tr {
        display: grid;
        grid-template-columns: repeat(7, 1fr) auto;
        grid-template-rows: auto auto auto;
        column-gap: 4px;
        row-gap: 8px;
        padding: 12px 14px;
        margin-bottom: 8px;
        background: var(--bg-soft);
        border: 1px solid var(--line);
        border-radius: var(--r-md);
        align-items: center;
    }
    .week-grid tbody tr:hover { background: var(--bg-soft); }

    .week-grid tbody td {
        padding: 0;
        border: 0;
        text-align: center;
        vertical-align: middle;
    }
    .week-grid td.cell-name {
        grid-row: 1;
        grid-column: 1 / 8;
        text-align: left;
        font-size: 15px;
        font-weight: 600;
        padding: 0;
        line-height: 1.25;
    }
    .week-grid td.cell-sum {
        grid-row: 1;
        grid-column: 8;
        text-align: right;
        padding: 0;
        font-size: 16px;
    }
    .week-grid td.cell-meta {
        grid-row: 2;
        grid-column: 1 / -1;
        text-align: left;
        padding: 0;
        font-size: 11px;
        color: var(--fg-faded);
    }
    .week-grid td.cell-meta .neg-tag { margin-left: 6px; }

    .week-grid td.day-td {
        grid-row: 3;
        padding: 0;
        position: relative;
    }
    .week-grid td.day-td::before {
        content: attr(data-dow);
        display: block;
        font-size: 10px;
        font-weight: 600;
        color: var(--fg-faded);
        text-transform: uppercase;
        letter-spacing: 0.04em;
        margin-bottom: 4px;
        text-align: center;
    }
    .week-grid td.day-td .day-cell {
        width: 100%;
        height: 36px;
        font-size: 12px;
        border-radius: var(--r-sm);
        margin: 0;
    }

    .todo-add {
        grid-template-columns: 1fr;
    }
    .todo-add select { min-width: 0; }
    .todos-head { gap: 12px; }
    .display { font-size: 32px; }

    /* Color picker auf mobile wrappen statt rechts neben dem Label */
    .stacked-form label.row {
        grid-template-columns: 1fr;
        gap: 8px;
    }
    .stacked-form label.row input {
        max-width: none;
        text-align: left;
    }
    .color-picker { gap: 10px; }
    .color-swatch { width: 32px; height: 32px; }

    /* Chip-Edit-Affordance mobil etwas größer für Tap-Target */
    .chip-edit { padding: 0 14px; min-width: 38px; }
}

@media (max-width: 380px) {
    .week-grid td.cell-name { font-size: 14px; }
    .week-grid td.day-td .day-cell { height: 34px; font-size: 11px; }
    .color-swatch { width: 28px; height: 28px; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
}

/* ---------- Export buttons ---------- */
.export-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 12px;
    background: var(--bg-soft);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    font-size: 12px;
    font-weight: 500;
    color: var(--fg-soft);
    transition: all 0.15s;
    letter-spacing: 0.02em;
}
.export-btn:hover {
    border-color: var(--accent-deep);
    color: var(--accent);
    background: var(--bg-elev);
}
.export-btn .export-icon {
    font-size: 14px;
    line-height: 1;
}
.stats-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 20px;
}

/* Print-only elements hidden on screen */
.print-only { display: none; }

/* ---------- Print stylesheet ---------- */
@media print {
    /* Force paper colors */
    :root {
        --bg:           #ffffff;
        --bg-soft:      #ffffff;
        --bg-elev:      #ffffff;
        --bg-strong:    #f7f4ff;
        --bg-input:     #ffffff;
        --fg:           #1a1a1a;
        --fg-soft:      #3a3a3a;
        --fg-faded:     #666666;
        --fg-dim:       #999999;
        --line:         #d4d4d4;
        --line-soft:    #e8e8e8;
        --line-strong:  #c0c0c0;
        --accent:       #6b4fb5;
        --accent-soft:  #8a6fd0;
        --accent-deep:  #4a2e93;
        --accent-tint:  #f1eaff;
        --accent-tint-2:#e6d9fb;
        --accent-glow:  transparent;
        --success:      #2d6b48;
        --success-tint: #dff0e7;
        --warn:         #8e7320;
        --warn-tint:    #f7edd0;
        --danger:       #a83d2d;
        --danger-tint:  #fbe2dc;
    }

    /* Use system serif/sans for print readability */
    body {
        background: white !important;
        color: #1a1a1a !important;
        font-size: 11pt;
        line-height: 1.4;
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
        color-adjust: exact;
    }
    body::before { display: none !important; }

    /* Hide chrome */
    .topbar,
    .tabs,
    .user,
    .no-print,
    .nav-arrow,
    .nav-today,
    .hint,
    .todo-add,
    .todos-filter,
    .group-chip.add,
    #btn-new-habit,
    .btn-primary,
    .h-edit,
    .todo-del,
    .modal,
    .sheet,
    .toast,
    .splash-tag,
    #view-splash,
    #view-setup,
    #view-login,
    .form-shell {
        display: none !important;
    }

    /* Show only active tab panel */
    .view#view-app { display: block !important; }
    .tab-panel[hidden] { display: none !important; }
    .tab-panel { display: block !important; }

    /* Show print header */
    .print-only { display: block !important; }
    #print-header {
        display: flex !important;
        align-items: baseline;
        justify-content: space-between;
        gap: 16px;
        padding: 0 0 12px;
        margin: 0 0 24px;
        border-bottom: 2px solid #1a1a1a;
    }
    .print-brand {
        font-size: 18pt;
        font-weight: 700;
        letter-spacing: -0.02em;
        color: var(--accent-deep);
    }
    .print-meta {
        font-size: 10pt;
        color: #555;
        display: flex; align-items: center; gap: 10px;
    }
    .print-dot { color: #aaa; }

    /* Page layout */
    @page {
        margin: 14mm 12mm;
        size: A4 portrait;
    }
    /* For the week view we prefer landscape (more horizontal room).
       Browsers can't switch @page size from a body class, but most users
       will pick the orientation themselves in the print dialog. The grid
       gracefully fits portrait at small font sizes if landscape isn't chosen. */
    body.print-landscape @page { size: A4 landscape; }

    .tab-panel {
        padding: 0 !important;
        max-width: none !important;
    }

    /* Week head */
    .week-head {
        grid-template-columns: 1fr auto !important;
        gap: 16px !important;
        margin-bottom: 16px !important;
        padding-bottom: 12px !important;
        border-bottom: 1px solid #ccc !important;
        page-break-inside: avoid;
    }
    .week-nav { gap: 12px !important; }
    .week-kw { font-size: 22pt !important; color: #1a1a1a !important; }
    .week-range { font-size: 10pt !important; color: #555 !important; }
    .score { min-width: auto !important; }
    .score-number { gap: 4px !important; }
    .score-current { font-size: 32pt !important; color: #1a1a1a !important; }
    .score-current.success { color: var(--success) !important; }
    .score-current.fail    { color: var(--danger) !important; }
    .score-divider { font-size: 16pt !important; color: #888 !important; }
    .score-goal { font-size: 16pt !important; color: #555 !important; }
    .score-bar {
        background: #eee !important;
        border: 1px solid #ddd !important;
    }
    .score-bar-fill {
        background: var(--accent) !important;
        box-shadow: none !important;
    }
    .score-meta { font-size: 9pt !important; color: #666 !important; }

    /* Week grid */
    .grid-wrap {
        overflow: visible !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    .week-grid {
        min-width: 0 !important;
        width: 100% !important;
        font-size: 10pt !important;
    }
    .week-grid thead th {
        color: #555 !important;
        font-size: 8pt !important;
        padding: 4px 0 8px !important;
        border-bottom: 1px solid #aaa !important;
    }
    .week-grid thead th.col-name { min-width: 0 !important; }
    .week-grid thead th.col-meta { min-width: 0 !important; }
    .week-grid tbody tr {
        page-break-inside: avoid;
        background: none !important;
    }
    .week-grid tbody td {
        padding: 6px 2px !important;
        border-bottom: 1px solid #eee !important;
    }
    .week-grid tbody td.cell-name {
        font-size: 10pt !important;
        color: #1a1a1a !important;
    }
    .week-grid tbody td.cell-meta {
        font-size: 8pt !important;
        color: #666 !important;
    }
    .week-grid tbody td.cell-sum {
        font-size: 11pt !important;
        color: #1a1a1a !important;
    }
    .week-grid tbody td.cell-sum.success { color: var(--success) !important; }
    .week-grid tbody td.cell-sum.fail    { color: var(--danger) !important; }

    .day-cell {
        width: 36px !important;
        height: 36px !important;
        background: white !important;
        border: 1px solid #d0d0d0 !important;
        color: #444 !important;
        box-shadow: none !important;
        transform: none !important;
    }
    .day-cell.filled {
        background: var(--accent-tint) !important;
        border-color: var(--accent) !important;
        color: var(--accent-deep) !important;
    }
    .day-cell.over-target {
        background: var(--accent) !important;
        color: white !important;
        border-color: var(--accent-deep) !important;
    }
    .day-cell.fail {
        background: var(--danger-tint) !important;
        border-color: var(--danger) !important;
        color: var(--danger) !important;
    }
    .day-cell.today {
        box-shadow: 0 0 0 2px white, 0 0 0 3px var(--accent) !important;
    }
    .day-cell .dot {
        background: #bbb !important;
    }

    /* Stats */
    .stats-summary {
        gap: 8px !important;
        margin-bottom: 16px !important;
    }
    .stat-card {
        background: white !important;
        border: 1px solid #d0d0d0 !important;
        padding: 12px 14px !important;
        page-break-inside: avoid;
    }
    .stat-card::after { display: none; }
    .stat-num {
        font-size: 26pt !important;
        color: var(--accent-deep) !important;
    }
    .stat-cap {
        font-size: 9pt !important;
        color: #555 !important;
    }
    .stat-cap small { color: #777 !important; }

    .chart-wrap {
        background: white !important;
        border: 1px solid #d0d0d0 !important;
        padding: 12px !important;
        margin-bottom: 16px !important;
        page-break-inside: avoid;
    }
    .section-title {
        font-size: 9pt !important;
        color: #555 !important;
    }
    .section-title small { color: #777 !important; }

    .bar-chart {
        height: 140px !important;
        padding: 18px 4px 4px !important;
    }
    .bar-shape {
        background: var(--accent-tint-2) !important;
        border-color: var(--accent-tint-2) !important;
        box-shadow: none !important;
    }
    .bar-shape.reached {
        background: var(--accent) !important;
        border-color: var(--accent-deep) !important;
    }
    .bar-shape.is-negative {
        background: var(--danger-tint) !important;
        border-color: var(--danger) !important;
    }
    .bar-label { color: #555 !important; font-size: 7pt !important; }
    .bar-val { color: #333 !important; font-size: 8pt !important; }
    .bar-col.is-current .bar-label,
    .bar-col.is-current .bar-val { color: var(--accent-deep) !important; }

    .dow-chart { gap: 4px !important; }
    .dow-cell {
        background: white !important;
        border: 1px solid #d0d0d0 !important;
    }
    .dow-cell .dow-fill { background: var(--accent-tint-2) !important; }
    .dow-cell .dow-name { color: #555 !important; font-size: 8pt !important; }
    .dow-cell .dow-val { color: #1a1a1a !important; font-size: 11pt !important; }

    .ranking li {
        background: white !important;
        border: 1px solid #d0d0d0 !important;
        padding: 8px 12px !important;
        page-break-inside: avoid;
    }
    .ranking li .rank { color: var(--accent-deep) !important; }
    .ranking li .r-name { color: #1a1a1a !important; font-size: 10pt !important; }
    .ranking li .r-num  { color: #555 !important; font-size: 9pt !important; }

    /* Avoid orphans/widows */
    h1, h2, h3 { page-break-after: avoid; }
}
