:root {
    color-scheme: light;
    --bg-a: #eaf4f7;
    --bg-b: #f7eef1;
    --bg-c: #f6f8fb;
    --glass: rgba(255, 255, 255, 0.54);
    --glass-strong: rgba(255, 255, 255, 0.76);
    --glass-soft: rgba(255, 255, 255, 0.34);
    --stroke: rgba(255, 255, 255, 0.68);
    --stroke-muted: rgba(88, 101, 112, 0.12);
    --ink: #26383d;
    --ink-soft: #64737b;
    --muted: #8a969d;
    --accent: #7897a5;
    --accent-warm: #c9918e;
    --danger: #a85d63;
    --focus: rgba(120, 151, 165, 0.28);
    --glow-a: rgba(166, 212, 220, 0.58);
    --glow-b: rgba(231, 196, 204, 0.62);
    --glow-c: rgba(208, 223, 235, 0.72);
    --ring-a: rgba(255, 255, 255, 0.38);
    --ring-b: rgba(255, 255, 255, 0.32);
    --ring-c: rgba(255, 255, 255, 0.28);
    --blur: blur(26px) saturate(1.18);
    --shadow: 0 24px 80px rgba(72, 92, 108, 0.14);
    --shadow-soft: 0 12px 30px rgba(72, 92, 108, 0.09);
    --inner-light: inset 0 1px 0 rgba(255, 255, 255, 0.75);
    --button-pad-x: 18px;
    font-family: "Segoe UI Variable Text", "Segoe UI Variable", "Aptos", "Inter", ui-sans-serif, system-ui, sans-serif;
}

@font-face {
    font-family: "Letters for Learners";
    src: url("fonts/LettersForLearners.ttf") format("truetype");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

html[data-skin="sage"] {
    --bg-a: #edf7f1;
    --bg-b: #f6f3ea;
    --bg-c: #eef4f5;
    --ink: #263b34;
    --ink-soft: #61766f;
    --muted: #8b9a94;
    --accent: #739b87;
    --accent-warm: #c49a72;
    --danger: #a86661;
    --focus: rgba(115, 155, 135, 0.28);
    --glow-a: rgba(156, 212, 181, 0.56);
    --glow-b: rgba(231, 211, 171, 0.48);
    --glow-c: rgba(191, 219, 209, 0.64);
}

html[data-skin="sunrise"] {
    --bg-a: #fff0e7;
    --bg-b: #f7eef6;
    --bg-c: #f5fbf7;
    --ink: #423437;
    --ink-soft: #7d6870;
    --muted: #a08e94;
    --accent: #bd8277;
    --accent-warm: #d3a150;
    --danger: #b65f6d;
    --focus: rgba(189, 130, 119, 0.28);
    --glow-a: rgba(242, 176, 136, 0.54);
    --glow-b: rgba(222, 176, 207, 0.48);
    --glow-c: rgba(192, 223, 196, 0.5);
}

html[data-skin="lavender"] {
    --bg-a: #f1effc;
    --bg-b: #eef6fb;
    --bg-c: #faf2f7;
    --ink: #303447;
    --ink-soft: #666d85;
    --muted: #9298aa;
    --accent: #7f89bb;
    --accent-warm: #c38f9d;
    --danger: #a65d75;
    --focus: rgba(127, 137, 187, 0.3);
    --glow-a: rgba(188, 183, 234, 0.58);
    --glow-b: rgba(178, 217, 232, 0.5);
    --glow-c: rgba(229, 190, 212, 0.52);
}

html[data-skin="forest"] {
    --bg-a: #ecf4ee;
    --bg-b: #f5f2e8;
    --bg-c: #eef1e8;
    --ink: #283b2e;
    --ink-soft: #657865;
    --muted: #8e9a8d;
    --accent: #5f8a6d;
    --accent-warm: #b99054;
    --danger: #9d6261;
    --focus: rgba(95, 138, 109, 0.28);
    --glow-a: rgba(132, 190, 146, 0.54);
    --glow-b: rgba(220, 198, 146, 0.44);
    --glow-c: rgba(187, 210, 177, 0.58);
}

html[data-skin="ocean"] {
    --bg-a: #e8f5f8;
    --bg-b: #eef3fb;
    --bg-c: #f5f7ef;
    --ink: #243943;
    --ink-soft: #607883;
    --muted: #8b9aa2;
    --accent: #5f9aab;
    --accent-warm: #c28d74;
    --danger: #a65f67;
    --focus: rgba(95, 154, 171, 0.28);
    --glow-a: rgba(126, 205, 219, 0.56);
    --glow-b: rgba(173, 198, 234, 0.48);
    --glow-c: rgba(204, 220, 178, 0.48);
}

html[data-skin="graphite"] {
    --bg-a: #eef1f3;
    --bg-b: #f7f4ef;
    --bg-c: #f0f3f5;
    --ink: #2f3438;
    --ink-soft: #69727a;
    --muted: #90979d;
    --accent: #74808a;
    --accent-warm: #b48368;
    --danger: #9f6068;
    --focus: rgba(116, 128, 138, 0.28);
    --glow-a: rgba(179, 189, 197, 0.52);
    --glow-b: rgba(222, 205, 190, 0.48);
    --glow-c: rgba(192, 205, 211, 0.56);
}

* {
    box-sizing: border-box;
}

html {
    min-height: 100%;
}

body {
    margin: 0;
    min-height: 100vh;
    background:
        radial-gradient(circle at 12% 8%, var(--glow-a), transparent 26%),
        radial-gradient(circle at 86% 6%, var(--glow-b), transparent 30%),
        radial-gradient(circle at 76% 88%, var(--glow-c), transparent 34%),
        linear-gradient(135deg, var(--bg-a), var(--bg-b) 48%, var(--bg-c));
    color: var(--ink);
}

body::before {
    position: fixed;
    inset: -12% -10% -18% -10%;
    pointer-events: none;
    content: "";
    background:
        radial-gradient(ellipse at 18% 22%, transparent 0 34%, var(--ring-a) 34.2% 34.55%, transparent 34.75%),
        radial-gradient(ellipse at 84% 18%, transparent 0 28%, var(--ring-b) 28.15% 28.5%, transparent 28.7%),
        radial-gradient(ellipse at 72% 82%, transparent 0 40%, var(--ring-c) 40.15% 40.42%, transparent 40.65%),
        linear-gradient(rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0));
    opacity: 1;
}

body::after {
    position: fixed;
    inset: 78px 40px auto;
    height: min(74vh, 720px);
    pointer-events: none;
    content: "";
    border: 1px solid rgba(255, 255, 255, 0.52);
    border-radius: 24px;
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.04));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.42);
    opacity: 0.78;
}

button,
input {
    font: inherit;
}

button {
    min-width: max-content;
    border: 0;
    cursor: pointer;
    white-space: nowrap;
    transition: transform 140ms ease, box-shadow 140ms ease, background 140ms ease, color 140ms ease;
}

button:hover {
    transform: translateY(-1px);
}

button:active {
    transform: translateY(0);
}

button:focus-visible,
a:focus-visible,
input:focus-visible {
    outline: 3px solid var(--focus);
    outline-offset: 3px;
}

.login-shell {
    position: relative;
    z-index: 1;
    display: grid;
    min-height: 100vh;
    place-items: center;
    padding: 24px;
}

.glass-panel,
.login-panel,
.topbar,
.daybar,
.settings-panel,
.empty-state,
.error-state {
    border: 1px solid var(--stroke);
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.82), rgba(255, 255, 255, 0.32)),
        var(--glass);
    backdrop-filter: var(--blur);
    -webkit-backdrop-filter: var(--blur);
    box-shadow: var(--shadow), var(--inner-light);
}

.login-panel {
    width: min(430px, 100%);
    padding: 30px;
    border-radius: 22px;
}

.eyebrow,
.module-kicker {
    margin: 0 0 5px;
    color: color-mix(in srgb, var(--accent) 74%, var(--ink));
    font-size: 0.7rem;
    font-weight: 520;
    letter-spacing: 0;
    text-transform: uppercase;
}

h1 {
    margin: 0;
    font-size: clamp(1.42rem, 2.25vw, 1.9rem);
    font-weight: 560;
    line-height: 1.08;
}

.login-copy,
.hint {
    color: var(--muted);
}

.login-form {
    display: grid;
    gap: 14px;
    margin-top: 22px;
}

label {
    display: grid;
    gap: 7px;
    color: var(--ink-soft);
    font-size: 0.9rem;
    font-weight: 480;
}

input {
    width: 100%;
    min-height: 42px;
    border: 1px solid var(--stroke);
    border-radius: 12px;
    padding: 9px 13px;
    background: rgba(255, 255, 255, 0.46);
    color: var(--ink);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7), 0 8px 20px rgba(72, 92, 108, 0.05);
    transition: border-color 140ms ease, box-shadow 140ms ease, background 140ms ease;
}

input::placeholder {
    color: #8d989f;
}

input:focus {
    border-color: rgba(120, 151, 165, 0.58);
    outline: 0;
    background: rgba(255, 255, 255, 0.68);
    box-shadow: 0 0 0 4px var(--focus), inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

.login-form button,
.settings-section > button,
.settings-toggle,
.secondary-button {
    min-height: 38px;
    border-radius: 999px;
    padding: 0 var(--button-pad-x);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.74), rgba(255, 255, 255, 0.34)),
        rgba(255, 255, 255, 0.52);
    color: var(--ink-soft);
    font-weight: 560;
    box-shadow: var(--shadow-soft), var(--inner-light);
}

.login-form button:hover,
.settings-section > button:hover,
.settings-toggle:hover,
.secondary-button:hover {
    color: color-mix(in srgb, var(--accent) 72%, var(--ink));
}

.alert {
    margin-top: 16px;
    padding: 10px 12px;
    border-radius: 12px;
    background: rgba(248, 223, 219, 0.7);
    color: var(--danger);
    font-weight: 760;
}

.app-shell {
    position: relative;
    z-index: 1;
    min-height: 100vh;
    padding: 14px;
}

.app-shell::before {
    position: fixed;
    inset: 96px 48px auto;
    z-index: -1;
    height: min(66vh, 640px);
    border-radius: 22px;
    pointer-events: none;
    content: "";
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.08)),
        rgba(255, 255, 255, 0.16);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

.topbar,
.daybar {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
}

.topbar {
    position: sticky;
    top: 12px;
    z-index: 20;
    display: grid;
    grid-template-columns: minmax(160px, 1fr) auto minmax(160px, 1fr);
    min-height: 58px;
    padding: 10px 14px;
    border-radius: 18px;
    margin: 0 auto 14px;
}

.topbar-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
}

.topbar-brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.topbar-brand h1 {
    min-width: 0;
}

.topbar-brand .home-guide-toggle.icon-only {
    width: 38px;
    min-width: 38px;
    height: 38px;
    min-height: 38px;
    padding: 0;
    border: 1px solid var(--stroke);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.38);
    color: var(--muted);
    font-size: 0.9rem;
    box-shadow: var(--shadow-soft), var(--inner-light);
}

.topbar-brand .home-guide-toggle.icon-only.is-admin-role {
    border-color: var(--stroke);
    background: rgba(255, 255, 255, 0.38);
    color: var(--muted);
    font-weight: 520;
}

.topbar h1::before {
    display: none;
}

.user-badge {
    display: none;
    align-items: center;
    min-height: 34px;
    border: 1px solid var(--stroke);
    border-radius: 999px;
    padding: 0 14px;
    background: rgba(255, 255, 255, 0.38);
    color: var(--muted);
    font-weight: 520;
    box-shadow: var(--inner-light);
    white-space: nowrap;
}

.logout-link {
    display: inline-grid;
    width: 38px;
    height: 38px;
    min-width: 38px;
    place-items: center;
    border: 1px solid var(--stroke);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.38);
    color: var(--ink-soft);
    font-size: 1rem;
    font-weight: 520;
    text-decoration: none;
    white-space: nowrap;
    box-shadow: var(--shadow-soft), var(--inner-light);
}

.logout-link:hover {
    color: color-mix(in srgb, var(--accent) 72%, var(--ink));
}

.daybar {
    justify-self: center;
    justify-content: flex-start;
    width: fit-content;
    padding: 6px;
    border-radius: 14px;
    margin: 0;
    background: rgba(255, 255, 255, 0.28);
    box-shadow: var(--inner-light);
}

.daybar input {
    position: absolute;
    width: 1px;
    min-width: 1px;
    max-width: 1px;
    height: 1px;
    min-height: 1px;
    overflow: hidden;
    border: 0;
    padding: 0;
    opacity: 0;
    pointer-events: none;
}

.date-display-text {
    min-width: max-content;
    color: var(--ink-soft);
    font-size: 0.92rem;
    font-weight: 430;
    letter-spacing: 0;
    white-space: nowrap;
}

.date-display-text.is-today {
    color: #168a5a;
    font-weight: 650;
}

.calendar-button {
    font-size: 0.82rem;
}

.daybar .icon-button,
.daybar .today-compact {
    border: 1px solid var(--stroke);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.42);
    box-shadow: var(--inner-light);
}

.daybar .icon-button:hover,
.daybar .today-compact:hover {
    background: rgba(255, 255, 255, 0.72);
}

.daybar input[type="date"]::-webkit-calendar-picker-indicator {
    display: none;
    opacity: 0;
    width: 0;
    height: 0;
    margin: 0;
    -webkit-appearance: none;
}

.daybar input[type="date"]::-webkit-inner-spin-button,
.daybar input[type="date"]::-webkit-clear-button {
    display: none;
    -webkit-appearance: none;
}

.icon-button {
    display: inline-grid;
    width: 38px;
    height: 38px;
    min-width: 38px;
    place-items: center;
    border-radius: 12px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0.3)),
        rgba(255, 255, 255, 0.5);
    color: var(--ink-soft);
    font-size: 1.45rem;
    font-weight: 520;
    box-shadow: var(--shadow-soft), var(--inner-light);
}

.icon-button.compact {
    width: 38px;
    height: 38px;
    min-width: 38px;
    font-size: 1.05rem;
}

.settings-toggle.icon-only,
.share-toggle.icon-only,
.home-guide-toggle.icon-only,
.fullscreen-toggle.icon-only {
    width: 38px;
    min-width: 38px;
    height: 38px;
    min-height: 38px;
    padding: 0;
}

.member-tabs {
    display: none;
}

.board {
    position: relative;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(236px, 1fr));
    gap: 14px;
    width: 100%;
    margin: 0 auto;
}

@media (min-width: 761px) {
    .board {
        display: flex;
        flex-wrap: nowrap;
        align-items: flex-start;
        overflow-x: auto;
        overflow-y: visible;
        scroll-snap-type: x proximity;
        scrollbar-width: thin;
    }

    .member-column {
        flex: 0 0 clamp(224px, calc((100vw - 48px) / 5), 330px);
        min-width: 224px;
        max-width: 330px;
        scroll-snap-align: start;
    }
}

.member-column {
    position: relative;
    z-index: 1;
    min-width: 0;
    padding: 12px;
    border: 1px solid rgba(255, 255, 255, 0.56);
    border-radius: 22px;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 9%, rgba(255, 255, 255, 0.24));
    backdrop-filter: var(--blur);
    -webkit-backdrop-filter: var(--blur);
    box-shadow: 0 28px 80px rgba(72, 92, 108, 0.11), var(--inner-light);
    animation: surfaceIn 220ms ease both;
}

.church-column-part {
    display: none;
}

.church-middle-body {
    display: contents;
}

.member-column.is-floating-host {
    z-index: 140;
}

.family-point-links {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 4;
    overflow: visible;
    pointer-events: none;
}

.family-point-links.is-under {
    z-index: 0;
}

.family-point-links.is-over {
    z-index: 4;
}

.family-point-links path {
    fill: none;
    stroke-linecap: round;
    stroke-width: 2px;
    opacity: 0.92;
    filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.62));
    vector-effect: non-scaling-stroke;
}

.member-header {
    margin-bottom: 8px;
    padding: 2px 6px 0;
}

.member-title {
    min-width: 0;
}

.member-title h2 {
    margin: 0;
    overflow: hidden;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 48%, var(--ink));
    font-size: 1rem;
    font-weight: 560;
    line-height: 1.16;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.member-title span {
    display: none;
    margin-top: 2px;
    color: var(--muted);
    font-size: 0.76rem;
    font-weight: 520;
}

.person-modules {
    display: grid;
    gap: 10px;
}

.person-module {
    position: relative;
    overflow: hidden;
    border-radius: 18px;
    container-type: inline-size;
    border: 1px solid var(--stroke);
    background: color-mix(in srgb, var(--member-color, var(--accent)) 7%, rgba(255, 255, 255, 0.58));
    backdrop-filter: var(--blur);
    -webkit-backdrop-filter: var(--blur);
    box-shadow: 0 18px 48px rgba(72, 92, 108, 0.08), var(--inner-light);
}

.module-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) max-content;
    align-items: center;
    gap: 10px;
    padding: 12px 12px 10px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.48);
    background: color-mix(in srgb, var(--member-color, var(--accent)) 6%, rgba(255, 255, 255, 0.2));
}

.module-header h3 {
    margin: 0;
    color: var(--ink);
    font-size: 0.96rem;
    font-weight: 560;
}

.add-task-toggle {
    min-width: 38px;
    width: 38px;
    min-height: 38px;
    height: 38px;
    border-radius: 999px;
    padding: 0;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 14%, rgba(255, 255, 255, 0.56));
    color: color-mix(in srgb, var(--member-color, var(--accent)) 58%, var(--ink));
    font-size: 1.18rem;
    font-weight: 560;
    box-shadow: var(--shadow-soft), var(--inner-light);
}

.icon-only {
    display: inline-grid;
    place-items: center;
    line-height: 1;
}

.add-task-toggle[aria-expanded="true"] {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 22%, rgba(255, 255, 255, 0.62));
}

.person-task-form {
    display: grid;
    gap: 10px;
    padding: 0 12px 12px;
}

.person-task-form[hidden] {
    display: none;
}

.composer-tabs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
}

.composer-context {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    min-height: 26px;
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 500;
}

.composer-context strong {
    overflow: hidden;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink));
    font-size: 0.76rem;
    font-weight: 560;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.composer-tab,
.delete-recurring-button {
    min-height: 32px;
    border-radius: 999px;
    padding: 0 12px;
    background: rgba(255, 255, 255, 0.38);
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 520;
    box-shadow: var(--inner-light);
}

.composer-tab.active {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 18%, rgba(255, 255, 255, 0.52));
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink));
}

.submit-task-button {
    min-height: 38px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 14%, rgba(255, 255, 255, 0.5));
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink));
    font-weight: 560;
    box-shadow: var(--shadow-soft), var(--inner-light);
}

.submit-task-button:hover {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 70%, var(--ink));
}

.phase-choice-group {
    display: grid;
    grid-template-columns: repeat(2, minmax(128px, 1fr));
    gap: 7px;
}

.composer-phase-choice {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.phase-choice {
    display: block;
    min-width: 0;
    color: var(--ink-soft);
    font-size: 0.78rem;
    font-weight: 520;
}

.phase-choice input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.phase-choice span {
    display: grid;
    min-height: 34px;
    place-items: center;
    overflow: hidden;
    border: 1px solid var(--stroke);
    border-radius: 999px;
    padding: 0 14px;
    background: rgba(255, 255, 255, 0.42);
    color: var(--muted);
    text-align: center;
    text-overflow: clip;
    white-space: nowrap;
    box-shadow: var(--inner-light);
}

.phase-choice input:checked + span {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 20%, rgba(255, 255, 255, 0.58));
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink));
}

.weekday-choice-group {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 5px;
}

.weekday-choice {
    min-width: 0;
}

.weekday-choice input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.weekday-choice span {
    display: grid;
    min-height: 30px;
    place-items: center;
    border: 1px solid var(--stroke);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.34);
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 520;
    box-shadow: var(--inner-light);
}

.weekday-choice input:checked + span {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 20%, rgba(255, 255, 255, 0.5));
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink));
}

.composer-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) max-content;
    gap: 8px;
}

.composer-row input,
.composer-row button {
    min-height: 40px;
}

.composer-row button {
    min-width: 42px;
    width: 42px;
    padding-inline: 0;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink));
}

.phase-grid {
    display: grid;
    gap: 6px;
    padding: 0 12px 12px;
}

.phase {
    border: 1px solid rgba(255, 255, 255, 0.56);
    border-radius: 10px;
    padding: 6px 8px;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 8%, rgba(255, 255, 255, 0.28));
    box-shadow: var(--inner-light);
}

.phase-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 0;
}

.phase-title h3 {
    margin: 0;
    overflow: hidden;
    color: var(--ink-soft);
    font-size: 0.82rem;
    font-weight: 560;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.phase-title h3::before {
    display: inline-block;
    width: 7px;
    height: 7px;
    margin-right: 7px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 68%, #ffffff);
    content: "";
    vertical-align: 1px;
}

.phase-title .add-task-toggle {
    width: 28px;
    min-width: 28px;
    height: 28px;
    min-height: 28px;
    border-radius: 10px;
    font-size: 1rem;
    box-shadow: var(--inner-light);
}

.count-pill {
    min-width: 24px;
    border-radius: 999px;
    padding: 2px 7px;
    background: rgba(255, 255, 255, 0.48);
    color: var(--muted);
    font-size: 0.75rem;
    font-weight: 520;
    text-align: center;
    box-shadow: var(--inner-light);
}

.task-list {
    display: grid;
    gap: 7px;
    min-height: 6px;
    margin-top: 5px;
}

.task-list:empty {
    display: none;
}

.task-item {
    position: relative;
    display: grid;
    grid-template-columns: 22px 1fr 24px;
    align-items: center;
    gap: 7px;
    min-height: 30px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.58);
    border-radius: 9px;
    padding: 3px 5px 3px 8px;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 8%, rgba(255, 255, 255, 0.46));
    box-shadow: var(--inner-light);
    transition: background 140ms ease, opacity 140ms ease, filter 140ms ease;
}

.task-item::before {
    position: absolute;
    inset: 9px auto 9px 0;
    width: 3px;
    border-radius: 0 999px 999px 0;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 62%, #ffffff);
    content: "";
}

.task-item:hover {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 12%, rgba(255, 255, 255, 0.54));
}

.task-item .task-state,
.task-item .task-title,
.task-item .delete-task {
    transform: none;
}

.task-item.done {
    color: #8a969d;
    background: rgba(255, 255, 255, 0.28);
}

.task-item.skipped {
    opacity: 0.52;
    filter: grayscale(0.35);
}

.task-item.done::before {
    background: #c2c9cd;
}

.task-item.done .task-title {
    text-decoration: line-through;
}

.task-check {
    display: grid;
    width: 18px;
    height: 18px;
    place-items: center;
    accent-color: color-mix(in srgb, var(--member-color, var(--accent)) 72%, #ffffff);
}

.task-state {
    display: inline-grid;
    width: 18px;
    height: 18px;
    min-width: 18px;
    place-items: center;
    border: 1px solid rgba(104, 119, 130, 0.42);
    border-radius: 5px;
    background: rgba(255, 255, 255, 0.32);
    color: color-mix(in srgb, var(--member-color, var(--accent)) 70%, var(--ink));
    font-size: 0.8rem;
    font-weight: 620;
    box-shadow: var(--inner-light);
    transition: background 140ms ease, border-color 140ms ease, color 140ms ease;
}

.task-item.status-pulse .task-state {
    animation: statusPulse 180ms ease both;
}

.task-title {
    width: 100%;
    min-width: 0;
    border: 0;
    padding: 0;
    background: transparent;
    color: inherit;
    text-align: left;
    overflow-wrap: anywhere;
    white-space: normal;
    font-size: 0.84rem;
    font-weight: 440;
    line-height: 1.18;
}

.delete-task,
.edit-task-toggle {
    width: 24px;
    height: 24px;
    min-width: 24px;
    border-radius: 8px;
    background: transparent;
    color: var(--muted);
    font-size: 1.05rem;
}

.recurring .task-title::after {
    content: none;
}

.recurring-rule-list {
    display: grid;
    gap: 6px;
}

.recurring-rule {
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.24);
    box-shadow: var(--inner-light);
}

.recurring-rule summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    min-height: 32px;
    padding: 0 10px;
    cursor: pointer;
    color: var(--ink-soft);
    font-size: 0.78rem;
}

.recurring-rule small {
    color: var(--muted);
}

.recurring-rule.highlighted summary > span:first-child {
    color: var(--ink);
    font-weight: 650;
}

.recurring-rule-meta {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 5px;
    min-width: 0;
}

.recurring-rule-meta .task-marker {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 64%, var(--ink-soft));
}

.recurring-edit-form {
    display: grid;
    gap: 8px;
    padding: 8px;
}

.recurring-default-options {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    align-items: center;
}

.recurring-default-options::before {
    color: var(--muted);
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.035em;
    text-transform: uppercase;
    content: "Standard";
}

.effective-date-field {
    display: grid;
    grid-template-columns: max-content minmax(0, 1fr);
    gap: 8px;
    align-items: center;
    color: var(--muted);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.035em;
    text-transform: uppercase;
}

.effective-date-field input {
    min-width: 0;
    min-height: 30px;
    font-size: 0.74rem;
    text-transform: none;
    letter-spacing: 0;
}

.overwrite-future-field {
    display: flex;
    grid-column: 1 / -1;
    gap: 7px;
    align-items: center;
    color: var(--muted);
    font-size: 0.72rem;
    line-height: 1.2;
}

.overwrite-future-field input {
    width: 14px;
    min-width: 14px;
    min-height: 14px;
    accent-color: var(--accent);
}

.delete-recurring-button {
    justify-self: start;
    color: var(--danger);
}

.delete-task:hover,
.edit-task-toggle:hover {
    background: rgba(248, 223, 219, 0.58);
    color: var(--danger);
}

.settings-panel {
    position: fixed;
    top: 100px;
    right: 18px;
    z-index: 30;
    display: grid;
    width: min(390px, calc(100vw - 36px));
    gap: 14px;
    padding: 16px;
    border-radius: 20px;
}

.settings-panel[hidden] {
    display: none;
}

.home-guide-panel {
    position: fixed;
    top: 78px;
    left: clamp(14px, 4vw, 56px);
    z-index: 35;
    width: min(760px, calc(100vw - 28px));
    max-height: calc(100dvh - 104px);
    overflow: auto;
}

.home-guide-panel[hidden] {
    display: none;
}

.home-guide-card {
    display: grid;
    gap: 12px;
    border: 1px solid var(--stroke);
    border-radius: 18px;
    padding: 14px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.58)),
        var(--glass);
    backdrop-filter: var(--blur);
    -webkit-backdrop-filter: var(--blur);
    box-shadow: var(--shadow), var(--inner-light);
}

.home-guide-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) max-content;
    align-items: start;
    gap: 12px;
}

.home-guide-head h2,
.home-guide-section h3 {
    margin: 0;
}

.home-guide-head h2 {
    color: var(--ink);
    font-size: 1.05rem;
    font-weight: 560;
}

.home-guide-section {
    display: grid;
    gap: 7px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 12px;
    padding: 10px 12px;
    background: rgba(255, 255, 255, 0.48);
}

.home-guide-section h3 {
    color: color-mix(in srgb, var(--accent) 78%, var(--ink));
    font-size: 0.76rem;
    font-weight: 650;
    letter-spacing: 0.035em;
    text-transform: uppercase;
}

.home-guide-section h3 span {
    color: var(--muted);
    font-weight: 520;
    letter-spacing: 0;
}

.home-guide-section p,
.home-guide-section li {
    margin: 0;
    color: var(--ink-soft);
    font-size: 0.82rem;
    line-height: 1.35;
}

.home-guide-section ul {
    display: grid;
    gap: 6px;
    margin: 0;
    padding-left: 18px;
}

.home-guide-table {
    display: grid;
    gap: 5px;
}

.home-guide-table [role="row"] {
    display: grid;
    grid-template-columns: 1.08fr 1fr 1.18fr 0.9fr;
    gap: 6px;
    align-items: start;
    border-radius: 9px;
    padding: 7px 8px;
    background: rgba(255, 255, 255, 0.45);
}

.home-guide-table [role="row"]:first-child {
    background: color-mix(in srgb, var(--accent) 10%, rgba(255, 255, 255, 0.56));
}

.home-guide-table strong,
.home-guide-table span {
    min-width: 0;
    color: var(--ink-soft);
    font-size: 0.74rem;
    line-height: 1.25;
}

.home-guide-table strong {
    color: color-mix(in srgb, var(--accent) 72%, var(--ink));
    font-weight: 650;
}

.settings-head {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 12px;
}

.settings-head h2 {
    margin: 0;
    font-size: 1.25rem;
}

.settings-section {
    display: grid;
    gap: 10px;
    padding: 13px;
    border: 1px solid rgba(255, 255, 255, 0.58);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.34);
    box-shadow: var(--inner-light);
}

.settings-section h3 {
    margin: 0;
    color: var(--ink-soft);
    font-size: 0.95rem;
    font-weight: 540;
}

.settings-section p {
    margin: 0;
    color: var(--muted);
    font-size: 0.88rem;
    line-height: 1.35;
}

.member-editor-list {
    display: grid;
    gap: 12px;
    max-height: 42vh;
    overflow: auto;
    padding-right: 2px;
}

.member-edit-form {
    display: grid;
    gap: 9px;
    padding: 11px;
    border: 1px solid rgba(255, 255, 255, 0.54);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.26);
    box-shadow: var(--inner-light);
}

.settings-section input[type="color"] {
    width: 100%;
    height: 44px;
    padding: 5px;
}

.color-presets {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.color-presets.compact {
    gap: 6px;
}

.color-presets button {
    width: 36px;
    height: 36px;
    min-width: 36px;
    border: 1px solid rgba(255, 255, 255, 0.62);
    border-radius: 999px;
    background: var(--swatch);
    box-shadow: var(--shadow-soft), var(--inner-light);
}

.color-presets.compact button {
    width: 30px;
    height: 30px;
    min-width: 30px;
}

.danger-button {
    color: var(--danger) !important;
}

.empty-state,
.error-state {
    max-width: 720px;
    margin: 60px auto;
    padding: 20px;
    border-radius: 16px;
    color: var(--muted);
    text-align: center;
}

@media (hover: hover) and (pointer: fine) {
    .delete-task,
    .edit-task-toggle {
        opacity: 0.46;
    }

    .task-item:hover .delete-task,
    .delete-task:focus-visible,
    .task-item:hover .edit-task-toggle,
    .edit-task-toggle:focus-visible {
        opacity: 1;
    }
}

@container (max-width: 390px) {
    .module-header {
        grid-template-columns: minmax(0, 1fr) max-content;
        align-items: center;
    }

    .add-task-toggle {
        justify-self: end;
    }

    .phase-choice-group {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .phase-choice span {
        min-height: 40px;
        padding-inline: 12px;
        white-space: normal;
        line-height: 1.05;
    }

    .composer-row {
        grid-template-columns: minmax(0, 1fr) max-content;
    }

    .composer-row button {
        justify-self: end;
    }

    .weekday-choice-group {
        grid-template-columns: repeat(7, minmax(24px, 1fr));
    }
}

@media (min-width: 761px) {
    .board {
        align-items: start;
    }
}

@media (min-width: 1500px) {
    .board {
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    }
}

@media (min-width: 1900px) {
    .board {
        grid-template-columns: repeat(auto-fit, minmax(205px, 1fr));
    }
}

@media (max-width: 760px) {
    body::after,
    .app-shell::before {
        display: none;
    }

    .app-shell {
        padding: 10px 0 16px;
    }

    .topbar,
    .daybar {
        margin-right: 10px;
        margin-left: 10px;
    }

    .topbar {
        top: 8px;
        grid-template-columns: minmax(0, 1fr) auto;
        min-height: 62px;
        align-items: flex-start;
    }

    .topbar h1 {
        font-size: 1.28rem;
    }

    .topbar-actions {
        flex-wrap: wrap;
        justify-content: flex-end;
        gap: 7px;
    }

    .settings-toggle {
        min-height: 36px;
        padding-inline: 0;
    }

    .daybar {
        grid-column: 1 / -1;
        grid-row: 2;
        justify-self: start;
        width: auto;
        flex-wrap: wrap;
    }

    .settings-panel {
        top: 88px;
        right: 10px;
        left: 10px;
        width: auto;
    }

    .member-tabs {
        position: sticky;
        top: 88px;
        z-index: 9;
        display: flex;
        gap: 8px;
        max-width: 100vw;
        margin: 0 0 10px;
        padding: 2px 10px 8px;
        overflow-x: auto;
        scrollbar-width: none;
    }

    .member-tabs::-webkit-scrollbar {
        display: none;
    }

    .member-tab {
        flex: 0 0 auto;
        min-height: 38px;
        border: 1px solid var(--stroke);
        border-radius: 999px;
        padding: 0 14px;
        background: rgba(255, 255, 255, 0.48);
        color: var(--ink-soft);
        font-weight: 620;
        backdrop-filter: var(--blur);
        -webkit-backdrop-filter: var(--blur);
        box-shadow: var(--shadow-soft), var(--inner-light);
    }

    .member-tab.active {
        background: color-mix(in srgb, var(--member-color, var(--accent)) 20%, rgba(255, 255, 255, 0.6));
        color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink));
    }

    .board {
        display: flex;
        gap: 12px;
        max-width: 100vw;
        padding: 0 10px 10px;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        scrollbar-width: none;
    }

    .board::-webkit-scrollbar {
        display: none;
    }

    .member-column {
        flex: 0 0 calc(100vw - 20px);
        scroll-snap-align: center;
        max-height: none;
    }

    .member-header {
        position: sticky;
        top: 142px;
        z-index: 3;
        margin: -2px -2px 8px;
        padding: 8px 10px;
        border: 1px solid rgba(255, 255, 255, 0.5);
        border-radius: 14px;
        background: color-mix(in srgb, var(--member-color, var(--accent)) 16%, rgba(255, 255, 255, 0.58));
        backdrop-filter: var(--blur);
        -webkit-backdrop-filter: var(--blur);
        box-shadow: var(--shadow-soft), var(--inner-light);
    }

    .module-header {
        grid-template-columns: minmax(0, 1fr) max-content;
        align-items: center;
        gap: 10px;
    }

    .add-task-toggle {
        justify-self: end;
        min-width: 38px;
        padding-inline: 0;
    }

    .phase-title .add-task-toggle {
        width: 28px;
        min-width: 28px;
        height: 28px;
        min-height: 28px;
    }

    .phase-choice-group {
        grid-template-columns: repeat(2, minmax(132px, 1fr));
    }

    .composer-row {
        grid-template-columns: minmax(0, 1fr) max-content;
    }

    .composer-row button {
        justify-self: end;
        min-width: 42px;
        padding-inline: 0;
    }
}

@container (max-width: 285px) {
    .module-header {
        grid-template-columns: minmax(0, 1fr);
    }

    .module-actions {
        justify-self: stretch;
    }

    .composer-phase-choice,
    .composer-tabs {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .presence-default-row {
        grid-template-columns: 20px minmax(58px, max-content) minmax(0, 1fr) minmax(0, 1fr);
        gap: 4px;
    }

    .presence-home-toggle {
        gap: 4px;
        font-size: 0.68rem;
    }

    .presence-default-row input[type="time"] {
        font-size: 0.68rem;
        padding-inline: 3px;
    }
}

@keyframes surfaceIn {
    from {
        opacity: 0;
        transform: translateY(8px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes statusPulse {
    0% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.14);
    }

    100% {
        transform: scale(1);
    }
}

/* Calm hub direction: flatter surfaces, lighter type, subtle family-color accents. */
:root {
    --bg-a: #f6f7f8;
    --bg-b: #f3f5f6;
    --bg-c: #fafafa;
    --glass: rgba(255, 255, 255, 0.88);
    --glass-strong: #ffffff;
    --glass-soft: rgba(255, 255, 255, 0.72);
    --stroke: rgba(37, 47, 56, 0.07);
    --stroke-muted: rgba(37, 47, 56, 0.08);
    --ink: #17212a;
    --ink-soft: #5d6874;
    --muted: #a0a8b2;
    --accent: #ff7048;
    --accent-warm: #c9918e;
    --danger: #a85d63;
    --focus: rgba(255, 112, 72, 0.2);
    --glow-a: rgba(255, 255, 255, 0.72);
    --glow-b: rgba(224, 232, 236, 0.46);
    --glow-c: rgba(237, 226, 221, 0.52);
    --ring-a: rgba(255, 255, 255, 0.34);
    --ring-b: rgba(255, 255, 255, 0.28);
    --ring-c: rgba(255, 255, 255, 0.22);
    --blur: none;
    --shadow: 0 18px 46px rgba(25, 34, 43, 0.045);
    --shadow-soft: 0 10px 26px rgba(25, 34, 43, 0.04);
    --inner-light: none;
    font-family: "Aptos", "Segoe UI Variable Text", "Segoe UI", ui-sans-serif, system-ui, sans-serif;
}

body {
    background: var(--bg-a);
}

body::before,
body::after,
.app-shell::before {
    display: none;
}

button {
    transition: background 120ms ease, border-color 120ms ease, color 120ms ease, opacity 120ms ease;
}

button:hover {
    transform: none;
}

.glass-panel,
.login-panel,
.topbar,
.daybar,
.settings-panel,
.empty-state,
.error-state {
    border-color: var(--stroke);
    background: rgba(255, 255, 255, 0.86);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: var(--shadow-soft);
}

.app-shell {
    padding: 20px clamp(18px, 4vw, 56px) 26px;
}

.topbar {
    position: relative;
    top: auto;
    grid-template-columns: minmax(190px, 1fr) auto minmax(190px, 1fr);
    min-height: 40px;
    margin-bottom: 34px;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.topbar h1 {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: #2b3036;
    font-size: 1.05rem;
    font-weight: 430;
    letter-spacing: 0;
}

.topbar h1::before {
    display: inline-grid;
    width: 30px;
    height: 30px;
    place-items: center;
    border-radius: 999px;
    background: #ffffff;
    color: var(--accent);
    content: "⌂";
    font-size: 0.88rem;
    box-shadow: 0 8px 20px rgba(25, 34, 43, 0.04);
}

.daybar {
    gap: 4px;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.daybar input {
    min-height: 34px;
    width: 176px;
    max-width: 176px;
    padding-right: 42px;
    border: 0;
    background: transparent;
    color: var(--ink-soft);
    box-shadow: none;
    text-align: left;
}

.daybar input.is-today {
    color: #2f8a5f;
    font-weight: 560;
}

.icon-button,
.logout-link,
.settings-toggle.icon-only,
.share-toggle.icon-only,
.home-guide-toggle.icon-only,
.fullscreen-toggle.icon-only,
.secondary-button,
.user-badge {
    border: 1px solid transparent;
    background: transparent;
    box-shadow: none;
    color: var(--muted);
    font-size: 0.86rem;
    font-weight: 430;
}

.icon-button,
.logout-link,
.settings-toggle.icon-only,
.share-toggle.icon-only,
.home-guide-toggle.icon-only,
.fullscreen-toggle.icon-only {
    width: 34px;
    height: 34px;
    min-width: 34px;
    border-radius: 999px;
}

.icon-button:hover,
.logout-link:hover,
.settings-toggle.icon-only:hover,
.share-toggle.icon-only:hover,
.home-guide-toggle.icon-only:hover,
.fullscreen-toggle.icon-only:hover,
.secondary-button:hover {
    background: #ffffff;
    color: var(--ink);
}

.secondary-button {
    min-height: 34px;
    padding-inline: 13px;
}

.today-compact.is-today {
    border-color: rgba(47, 138, 95, 0.34);
    color: #2f8a5f;
    font-weight: 560;
}

.fullscreen-toggle.is-active {
    border-color: rgba(47, 138, 95, 0.34);
    color: #2f8a5f;
}

.topbar-actions .home-guide-toggle.icon-only.is-admin-role {
    border-color: transparent;
    color: var(--muted);
    font-weight: 520;
}

.topbar-actions {
    gap: 8px;
}

.user-badge {
    min-height: 34px;
    padding: 0 10px;
}

.board {
    gap: 0;
    border: 1px solid var(--stroke);
    border-radius: 0;
    background: rgba(255, 255, 255, 0.34);
    box-shadow: none;
}

.member-column {
    min-height: 430px;
    padding: 30px 30px 24px;
    border: 0;
    border-right: 1px solid var(--stroke);
    border-radius: 0;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 4%, rgba(255, 255, 255, 0.82));
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: none;
    animation: none;
}

.member-column:last-child {
    border-right: 0;
}

.member-header {
    margin: 0 0 22px;
    padding: 0;
}

.member-title h2 {
    color: var(--ink);
    font-size: 1.02rem;
    font-weight: 430;
}

.flagged-list {
    display: grid;
    gap: 2px;
    margin-top: 7px;
}

.flagged-chip {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: 6px;
    align-items: baseline;
    min-height: 0;
    border: 0;
    border-radius: 0;
    padding: 0;
    background: transparent;
    color: var(--ink);
    box-shadow: none;
}

.flagged-chip span {
    display: block;
    grid-column: 2;
    grid-row: 1;
    overflow: hidden;
    font-size: 0.78rem;
    font-weight: 520;
    line-height: 1.2;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.flagged-chip small {
    grid-column: 1;
    grid-row: 1;
    color: var(--ink);
    font-size: 0.72rem;
    font-weight: 430;
    line-height: 1.2;
    text-align: left;
}

.flagged-chip small.is-urgent {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 78%, var(--ink));
    font-weight: 520;
}

.flagged-chip span {
    color: var(--ink);
}

.person-modules {
    gap: 16px;
}

.person-module {
    overflow: clip;
    border: 0;
    border-radius: 0;
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: none;
}

.person-task-form,
.presence-day-form,
.presence-defaults-form {
    max-width: 100%;
    min-width: 0;
}

.composer-tab,
.phase-choice span,
.weekday-choice span {
    min-width: 0;
    padding-inline: 8px;
}

.presence-default-row {
    min-width: 0;
}

.module-header {
    padding: 0 0 12px;
    border: 0;
    background: transparent;
}

.module-header h3,
.phase-title h3 {
    color: #a8b0ba;
    font-size: 0.69rem;
    font-weight: 520;
    letter-spacing: 0.045em;
    text-transform: uppercase;
}

.phase-title h3::before {
    display: none;
}

.phase-grid {
    gap: 3px;
    padding: 0;
}

.phase {
    padding: 8px 0 9px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.phase + .phase {
    border-top: 1px solid rgba(37, 47, 56, 0.045);
}

.phase-title {
    min-height: 24px;
}

.phase-title .add-task-toggle {
    width: 24px;
    min-width: 24px;
    height: 24px;
    min-height: 24px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 999px;
    background: #ffffff;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 74%, var(--ink));
    font-size: 0.95rem;
    font-weight: 380;
    opacity: 0.78;
    box-shadow: none;
}

.phase-title .add-task-toggle:hover,
.phase-title .add-task-toggle[aria-expanded="true"] {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 22%, rgba(37, 47, 56, 0.08));
    background: color-mix(in srgb, var(--member-color, var(--accent)) 10%, #ffffff);
    opacity: 1;
}

.task-list {
    gap: 2px;
    margin-top: 4px;
}

.task-item {
    grid-template-columns: 18px 1fr 20px;
    gap: 6px;
    min-height: 24px;
    border: 0;
    border-radius: 0;
    padding: 1px 0;
    background: transparent;
    box-shadow: none;
}

.task-item::before {
    display: none;
}

.task-item:hover {
    background: transparent;
}

.task-state {
    width: 12px;
    height: 12px;
    min-width: 12px;
    border: 1px solid rgba(95, 107, 120, 0.16);
    border-radius: 999px;
    background: transparent;
    color: #ffffff;
    font-size: 0.58rem;
    line-height: 1;
    box-shadow: none;
}

.task-item.done .task-state {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 76%, #ffffff);
    background: color-mix(in srgb, var(--member-color, var(--accent)) 76%, #ffffff);
}

.task-item.skipped .task-state {
    border-color: rgba(95, 107, 120, 0.12);
    background: #d9dde2;
    color: #ffffff;
}

.task-title {
    color: var(--ink);
    font-size: 0.82rem;
    font-weight: 390;
    line-height: 1.28;
}

.task-item.done .task-title {
    color: #9ba3ad;
    text-decoration: line-through;
    text-decoration-thickness: 1px;
}

.task-item.skipped {
    opacity: 0.48;
    filter: none;
}

.delete-task,
.edit-task-toggle {
    width: 20px;
    height: 20px;
    min-width: 20px;
    color: #c4c9cf;
    font-size: 0.82rem;
}

.delete-task:hover,
.edit-task-toggle:hover {
    background: transparent;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 70%, var(--ink));
}

.recurring .task-title::after {
    content: none;
}

.person-task-form {
    gap: 8px;
    margin: 0 0 9px;
    padding: 9px 0 12px;
    border-bottom: 1px solid rgba(37, 47, 56, 0.045);
}

.composer-context {
    min-height: 20px;
    color: #b4bac2;
}

.composer-context strong {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 72%, var(--ink));
    font-weight: 430;
}

.composer-tab,
.delete-recurring-button,
.submit-task-button {
    box-shadow: none;
}

.composer-tab {
    min-height: 28px;
    border: 1px solid rgba(37, 47, 56, 0.05);
    background: #ffffff;
    color: var(--muted);
    font-weight: 430;
}

.composer-tab.active {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 10%, #ffffff);
}

input {
    min-height: 36px;
    border-color: rgba(37, 47, 56, 0.07);
    background: #ffffff;
    box-shadow: none;
}

.composer-row input,
.composer-row button {
    min-height: 36px;
}

.composer-row button {
    width: 36px;
    min-width: 36px;
}

.submit-task-button {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 74%, #ffffff);
    color: #ffffff !important;
}

.weekday-choice span,
.phase-choice span {
    border-color: rgba(37, 47, 56, 0.06);
    background: #ffffff;
    box-shadow: none;
    font-weight: 430;
}

.recurring-rule {
    background: #ffffff;
    box-shadow: none;
}

.settings-panel,
.settings-section,
.member-edit-form,
.login-panel {
    background: #ffffff;
    box-shadow: var(--shadow);
}

.settings-section {
    border-color: var(--stroke);
}

@media (min-width: 1500px) {
    .board {
        grid-template-columns: repeat(auto-fit, minmax(245px, 1fr));
    }
}

@media (min-width: 1900px) {
    .board {
        grid-template-columns: repeat(auto-fit, minmax(235px, 1fr));
    }
}

@media (max-width: 760px) {
    .app-shell {
        padding: 12px 0 18px;
    }

    .topbar {
        position: sticky;
        top: 0;
        grid-template-columns: minmax(0, 1fr) auto;
        margin: 0 10px 14px;
        padding: 8px 0;
        background: rgba(246, 247, 248, 0.92);
    }

    .topbar h1 {
        font-size: 1rem;
    }

    .daybar {
        justify-self: start;
    }

    .member-tabs {
        display: none;
    }

    .member-tab {
        border-color: rgba(37, 47, 56, 0.06);
        background: #ffffff;
        box-shadow: none;
        font-weight: 430;
    }

    .member-tab.active {
        background: color-mix(in srgb, var(--member-color, var(--accent)) 12%, #ffffff);
    }

    .board {
        gap: 12px;
        border: 0;
        background: transparent;
    }

    .member-column {
        flex: 0 0 calc(100vw - 20px);
        min-height: auto;
        border: 1px solid var(--stroke);
        border-radius: 16px;
        padding: 18px;
        background: color-mix(in srgb, var(--member-color, var(--accent)) 5%, #ffffff);
    }

    .member-header {
        top: 58px;
        margin: -6px -6px 16px;
        padding: 10px 6px;
        border: 0;
        background: color-mix(in srgb, var(--member-color, var(--accent)) 8%, #ffffff);
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        box-shadow: none;
    }

    .flagged-list {
        margin-top: 8px;
    }

    .flagged-chip {
        min-height: 32px;
    }
}

/* Bento refinement: person card plus four quiet phase tiles. */
body {
    background:
        radial-gradient(circle at 16% 14%, var(--glow-a), transparent 28%),
        radial-gradient(circle at 86% 8%, var(--glow-b), transparent 30%),
        radial-gradient(circle at 78% 90%, var(--glow-c), transparent 34%),
        linear-gradient(135deg, var(--bg-a) 0%, var(--bg-b) 54%, var(--bg-c) 100%);
}

html[data-skin="glass"] {
    --bg-a: #edf6f8;
    --bg-b: #f6eef4;
    --bg-c: #f8fafc;
    --glass: rgba(255, 255, 255, 0.56);
    --glass-strong: rgba(255, 255, 255, 0.82);
    --glass-soft: rgba(255, 255, 255, 0.38);
    --stroke: rgba(255, 255, 255, 0.62);
    --stroke-muted: rgba(82, 98, 112, 0.1);
    --ink: #263842;
    --ink-soft: #637580;
    --muted: #8b99a3;
    --accent: #6d9fb1;
    --accent-warm: #c88f97;
    --focus: rgba(109, 159, 177, 0.28);
    --glow-a: rgba(145, 211, 224, 0.6);
    --glow-b: rgba(229, 185, 207, 0.58);
    --glow-c: rgba(199, 218, 236, 0.72);
    --blur: blur(26px) saturate(1.18);
    --shadow: 0 24px 80px rgba(72, 92, 108, 0.14);
    --shadow-soft: 0 12px 30px rgba(72, 92, 108, 0.09);
    --inner-light: inset 0 1px 0 rgba(255, 255, 255, 0.76);
}

html[data-skin="contrast"] {
    --bg-a: #ffffff;
    --bg-b: #f2f4f7;
    --bg-c: #ffffff;
    --glass: rgba(255, 255, 255, 0.96);
    --glass-strong: #ffffff;
    --glass-soft: rgba(255, 255, 255, 0.9);
    --stroke: rgba(17, 29, 43, 0.2);
    --stroke-muted: rgba(17, 29, 43, 0.16);
    --ink: #081421;
    --ink-soft: #314154;
    --muted: #5f6f80;
    --accent: #005fcc;
    --accent-warm: #b65c00;
    --danger: #9d1632;
    --focus: rgba(0, 95, 204, 0.32);
    --glow-a: rgba(255, 255, 255, 0.88);
    --glow-b: rgba(205, 219, 238, 0.64);
    --glow-c: rgba(238, 230, 218, 0.42);
    --shadow: 0 18px 46px rgba(17, 29, 43, 0.09);
    --shadow-soft: 0 10px 26px rgba(17, 29, 43, 0.07);
}

html[data-skin="kids"] {
    --bg-a: #fff5e7;
    --bg-b: #eef7ff;
    --bg-c: #f7f2ff;
    --ink: #243044;
    --ink-soft: #607084;
    --muted: #8d99aa;
    --accent: #3f80d9;
    --accent-warm: #df9d34;
    --danger: #c45d6a;
    --focus: rgba(63, 128, 217, 0.28);
    --glow-a: rgba(255, 199, 108, 0.46);
    --glow-b: rgba(126, 197, 235, 0.5);
    --glow-c: rgba(206, 171, 236, 0.46);
}

html[data-skin="metal"] {
    --bg-a: #eef1f3;
    --bg-b: #f7f4ef;
    --bg-c: #f0f3f5;
    --ink: #2e3438;
    --ink-soft: #68727a;
    --muted: #8f979e;
    --accent: #74808a;
    --accent-warm: #b48368;
    --danger: #9f6068;
    --focus: rgba(116, 128, 138, 0.28);
    --glow-a: rgba(179, 189, 197, 0.58);
    --glow-b: rgba(222, 205, 190, 0.5);
    --glow-c: rgba(192, 205, 211, 0.6);
}

html[data-skin="colorblind"] {
    --bg-a: #f3f7f8;
    --bg-b: #f7f4ec;
    --bg-c: #f8f8fb;
    --ink: #243744;
    --ink-soft: #637482;
    --muted: #8997a1;
    --accent: #0072b2;
    --accent-warm: #e69f00;
    --danger: #cc79a7;
    --focus: rgba(0, 114, 178, 0.28);
    --glow-a: rgba(121, 179, 212, 0.5);
    --glow-b: rgba(234, 197, 106, 0.36);
    --glow-c: rgba(172, 210, 184, 0.42);
}

html[data-skin="paper"] {
    --bg-a: #faf5ea;
    --bg-b: #f3efe5;
    --bg-c: #fbf8f0;
    --glass: rgba(255, 252, 244, 0.88);
    --glass-strong: #fffaf0;
    --glass-soft: rgba(255, 251, 242, 0.74);
    --stroke: rgba(99, 76, 44, 0.1);
    --stroke-muted: rgba(99, 76, 44, 0.09);
    --ink: #3c342b;
    --ink-soft: #73675b;
    --muted: #a09588;
    --accent: #8a9a76;
    --accent-warm: #bd8a5d;
    --danger: #a85e5c;
    --focus: rgba(138, 154, 118, 0.28);
    --glow-a: rgba(255, 247, 229, 0.76);
    --glow-b: rgba(219, 196, 156, 0.42);
    --glow-c: rgba(199, 214, 180, 0.38);
}

html[data-skin="zen"] {
    --bg-a: #f5f1e8;
    --bg-b: #ebe7dc;
    --bg-c: #f8f5ee;
    --glass: rgba(255, 251, 242, 0.82);
    --glass-strong: #fffaf0;
    --glass-soft: rgba(255, 251, 242, 0.62);
    --stroke: rgba(73, 66, 58, 0.12);
    --stroke-muted: rgba(73, 66, 58, 0.1);
    --ink: #28241f;
    --ink-soft: #625c54;
    --muted: #8c8579;
    --accent: #7f947a;
    --accent-warm: #a78967;
    --danger: #966363;
    --focus: rgba(127, 148, 122, 0.3);
    --glow-a: rgba(255, 255, 255, 0.46);
    --glow-b: rgba(173, 160, 139, 0.26);
    --glow-c: rgba(139, 161, 129, 0.2);
}

html[data-skin="frosted"] {
    --bg-a: #eaf7ff;
    --bg-b: #edf5fb;
    --bg-c: #f8fcff;
    --glass: rgba(233, 247, 255, 0.42);
    --glass-strong: rgba(246, 252, 255, 0.62);
    --glass-soft: rgba(224, 241, 252, 0.34);
    --stroke: rgba(255, 255, 255, 0.72);
    --stroke-muted: rgba(76, 117, 143, 0.12);
    --ink: #203847;
    --ink-soft: #5d788a;
    --muted: #8aa0af;
    --accent: #6da9c9;
    --accent-warm: #bd9bab;
    --danger: #9d6571;
    --focus: rgba(109, 169, 201, 0.3);
    --glow-a: rgba(174, 225, 255, 0.64);
    --glow-b: rgba(220, 240, 255, 0.78);
    --glow-c: rgba(187, 213, 245, 0.72);
    --blur: blur(32px) saturate(1.24);
    --shadow: 0 30px 90px rgba(80, 127, 158, 0.18);
    --shadow-soft: 0 14px 34px rgba(80, 127, 158, 0.12);
    --inner-light: inset 0 1px 0 rgba(255, 255, 255, 0.86);
}

html[data-skin="church"] {
    --bg-a: #1c1814;
    --bg-b: #2b241d;
    --bg-c: #0f0d0b;
    --glass: rgba(245, 229, 178, 0.54);
    --glass-strong: rgba(255, 241, 194, 0.74);
    --glass-soft: rgba(235, 204, 128, 0.34);
    --stroke: rgba(44, 44, 44, 0.86);
    --stroke-muted: rgba(44, 44, 44, 0.52);
    --ink: #1a1611;
    --ink-soft: #3d3429;
    --muted: #796a58;
    --accent: #b78b39;
    --accent-warm: #d18b35;
    --danger: #9b2638;
    --focus: rgba(255, 215, 88, 0.42);
    --glow-a: rgba(255, 215, 88, 0.26);
    --glow-b: rgba(120, 76, 34, 0.26);
    --glow-c: rgba(64, 43, 27, 0.46);
    --blur: blur(4px) brightness(1.12);
    --shadow: 0 28px 88px rgba(0, 0, 0, 0.36);
    --shadow-soft: 0 14px 36px rgba(0, 0, 0, 0.24);
    --inner-light: inset 1px 1px 2px rgba(255, 255, 255, 0.18);
}

.board {
    gap: 14px;
    border: 0;
    background: transparent;
}

.member-column {
    border: 1px solid rgba(255, 255, 255, 0.66);
    border-radius: 18px;
    background:
        color-mix(in srgb, var(--member-color, var(--accent)) 5%, rgba(255, 255, 255, 0.82));
    box-shadow:
        0 18px 46px rgba(25, 34, 43, 0.055),
        inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.member-column:last-child {
    border-right: 1px solid rgba(255, 255, 255, 0.66);
}

.person-module {
    padding: 14px;
    border: 1px solid rgba(255, 255, 255, 0.58);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.42);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.64);
}

.module-header {
    padding-bottom: 10px;
}

.phase-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
}

.phase {
    position: relative;
    min-height: 78px;
    padding: 9px;
    border: 1px solid rgba(255, 255, 255, 0.62);
    border-radius: 14px;
    background:
        color-mix(in srgb, var(--member-color, var(--accent)) 5%, rgba(255, 255, 255, 0.66));
    box-shadow:
        0 10px 26px rgba(25, 34, 43, 0.035),
        inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

.phase + .phase {
    border-top: 1px solid rgba(255, 255, 255, 0.62);
}

.phase-title {
    justify-content: flex-end;
    min-height: 22px;
}

.phase-title::before {
    position: absolute;
    top: 12px;
    left: 12px;
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 68%, #ffffff);
    content: "";
}

.phase-title h3 {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    white-space: nowrap;
}

.phase-title .add-task-toggle {
    border-color: rgba(255, 255, 255, 0.72);
    background: rgba(255, 255, 255, 0.64);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.76);
}

.task-list {
    margin-top: 4px;
}

.task-item {
    min-height: 25px;
}

.person-task-form {
    margin-bottom: 10px;
    padding: 10px;
    border: 1px solid rgba(255, 255, 255, 0.58);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.46);
}

@media (max-width: 760px) {
    .board {
        gap: 12px;
    }

    .phase-grid {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .phase {
        min-height: 68px;
    }

    .module-header {
        grid-template-columns: minmax(0, 1fr) auto;
    }

}

/* Readable phase stack: one glance, no decorative phase markers. */
.board {
    gap: 18px;
}

.member-column {
    padding: 24px;
}

.person-module {
    padding: 16px;
}

.phase-grid {
    grid-template-columns: 1fr;
    gap: 6px;
}

.phase {
    min-height: 42px;
    padding: 5px 10px 8px;
}

.phase-title {
    display: none;
    min-height: 0;
}

.phase-title::before {
    display: none;
}

.phase-title .add-task-toggle {
    margin-left: auto;
}

.task-list {
    gap: 3px;
    margin-top: 0;
}

.task-item {
    grid-template-columns: 18px minmax(0, 1fr) 20px;
    min-height: 26px;
    padding: 2px 0;
}

.task-edit-panel {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) repeat(4, 30px);
    gap: 7px;
    width: 100%;
    min-width: 0;
    margin-top: 5px;
    padding: 8px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.7);
    box-shadow: 0 8px 20px rgba(25, 34, 43, 0.045);
}

.task-edit-panel[hidden] {
    display: none;
}

.task-edit-panel input {
    min-width: 0;
    min-height: 32px;
}

.task-edit-panel button {
    min-height: 32px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    background: #ffffff;
    color: var(--ink-soft);
    font-size: 0.76rem;
    box-shadow: none;
}

.task-option {
    position: relative;
    display: inline-grid;
    place-items: center;
    width: 30px;
    min-width: 30px;
    min-height: 32px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    background: #ffffff;
    color: var(--ink-soft);
    font-size: 0.74rem;
    font-weight: 650;
}

.task-option span {
    display: inline-grid;
    place-items: center;
}

.task-option input {
    position: absolute;
    inset: 0;
    width: 100%;
    min-height: 100%;
    opacity: 0;
    cursor: pointer;
}

.task-option:has(input:checked) {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 34%, rgba(37, 47, 56, 0.08));
    background: color-mix(in srgb, var(--member-color, var(--accent)) 14%, #ffffff);
    color: color-mix(in srgb, var(--member-color, var(--accent)) 78%, var(--ink));
}

.task-rule-button {
    width: 32px;
    min-width: 32px;
    padding: 0;
}

.task-save-button {
    width: 34px;
    min-width: 34px;
    padding: 0;
}

.task-move-tomorrow {
    width: 34px;
    min-width: 34px;
    padding: 0;
    font-size: 0.7rem !important;
    font-weight: 700;
}

.task-delete-button {
    width: 32px;
    min-width: 32px;
    padding: 0;
    color: var(--danger) !important;
}

.task-title {
    overflow-wrap: break-word;
    word-break: normal;
    hyphens: auto;
}

.task-item.highlighted .task-title {
    font-weight: 650;
}

.recurring .task-title::after {
    content: none;
}

.task-title {
    display: block;
    align-items: flex-end;
}

.task-title > span:first-child {
    min-width: 0;
    overflow-wrap: break-word;
}

.task-title .task-marker,
.global-info-title .task-marker {
    display: inline-grid;
    margin-left: 4px;
    vertical-align: text-bottom;
}

.task-marker {
    flex: 0 0 auto;
    display: inline-grid;
    width: 0.95em;
    height: 0.95em;
    place-items: center;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 48%, var(--muted));
    line-height: 1;
}

.task-marker-icon {
    display: block;
    width: 0.95em;
    height: 0.95em;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.85;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.task-completion-warning {
    display: inline-grid;
    width: 1.05em;
    height: 1.05em;
    margin-right: 5px;
    place-items: center;
    color: color-mix(in srgb, var(--danger) 78%, #c79b45);
    line-height: 1;
    vertical-align: -0.16em;
}

.task-completion-warning svg {
    display: block;
    width: 1em;
    height: 1em;
    fill: color-mix(in srgb, currentColor 10%, transparent);
    stroke: currentColor;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.task-completion-warning-critical {
    color: var(--danger);
    animation: recurringCompletionPulse 1.9s ease-in-out infinite;
}

.task-item.done .task-completion-warning,
.task-item.skipped .task-completion-warning {
    display: none;
}

.task-option .task-marker-icon {
    width: 14px;
    height: 14px;
}

.task-state {
    border-color: rgba(92, 104, 116, 0.2);
    background: #ffffff;
}

.task-item.open .task-state {
    background: #ffffff;
}

.task-item.done {
    opacity: 1;
}

.task-item.done .task-state {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 82%, #ffffff);
    background: color-mix(in srgb, var(--member-color, var(--accent)) 82%, #ffffff);
    color: #ffffff;
}

.task-item.done .task-title {
    color: #9aa3ad;
    text-decoration: line-through;
}

.task-item.skipped {
    opacity: 1;
}

.task-item.skipped .task-state {
    border-color: #d7dce1;
    background: repeating-linear-gradient(135deg, #f0f2f4 0 3px, #e3e7eb 3px 6px);
    color: #8d96a1;
}

.task-item.skipped .task-title {
    color: #b0b7bf;
    font-style: normal;
    text-decoration: line-through;
    text-decoration-thickness: 1px;
}

.person-task-form {
    position: relative;
    margin: 0 0 12px;
    padding: 12px;
    border: 1px solid color-mix(in srgb, var(--member-color, var(--accent)) 18%, rgba(37, 47, 56, 0.08));
    border-radius: 14px;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 8%, rgba(255, 255, 255, 0.9));
    box-shadow: 0 14px 32px rgba(25, 34, 43, 0.07), inset 0 1px 0 rgba(255, 255, 255, 0.76);
}

.composer-context {
    min-height: 28px;
}

.composer-context > div {
    display: grid;
    gap: 2px;
}

.composer-context span {
    color: #9da7b2;
    font-size: 0.67rem;
    letter-spacing: 0.045em;
    text-transform: uppercase;
}

.composer-close {
    width: 28px;
    min-width: 28px;
    height: 28px;
    min-height: 28px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 999px;
    background: #ffffff;
    color: var(--muted);
    box-shadow: none;
}

.composer-close:hover {
    color: var(--danger);
}

.module-actions {
    display: grid;
    grid-template-columns: 30px;
    gap: 7px;
    align-items: start;
    justify-self: end;
    min-width: 0;
}

.module-actions > .add-task-toggle {
    width: 30px;
    min-width: 30px;
    height: 30px;
    min-height: 30px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 999px;
    background: #ffffff;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 74%, var(--ink));
    font-size: 1rem;
    font-weight: 430;
    opacity: 0.82;
    box-shadow: none;
}

.module-actions > .add-task-toggle:hover,
.module-actions > .add-task-toggle[aria-expanded="true"] {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 10%, #ffffff);
    opacity: 1;
}

.phase-presence-wrap {
    display: grid;
    gap: 0;
    margin: -3px 0 -2px;
}

.phase-presence-wrap .presence-day-form,
.phase-presence-wrap .presence-day-form:has(.presence-reset-day) {
    grid-template-columns: minmax(0, 1fr) 30px;
    gap: 7px;
}

.phase-presence-wrap .presence-day-form .presence-home-toggle {
    grid-column: 1;
}

.phase-presence-wrap .presence-day-form input[type="time"] {
    grid-column: 1 / -1;
    width: 100%;
    min-width: 0;
    min-height: 34px;
    padding-inline: 10px;
    text-align: left;
}

.phase-presence-wrap .presence-day-form input[type="time"]:first-of-type,
.phase-presence-wrap .presence-day-form input[type="time"]:last-of-type {
    grid-column: 1 / -1;
}

.phase-presence-wrap .presence-day-form input[type="time"]:last-of-type {
    margin-top: -2px;
}

.phase-presence-wrap .presence-day-form .presence-save-button {
    grid-column: 2;
    grid-row: 1;
}

.phase-presence-wrap .presence-day-form .presence-reset-day {
    grid-column: 2;
    grid-row: 2;
}

.module-header .school-presence,
.phase .school-presence {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 30px;
    gap: 7px;
    align-items: center;
    min-width: 0;
}

.phase .school-presence {
    grid-template-columns: minmax(0, 1fr) 20px;
    gap: 3px;
    min-height: 18px;
    align-items: center;
}

.module-header .school-presence.has-schedule,
.phase .school-presence.has-schedule {
    grid-template-columns: minmax(0, 1fr) 30px 30px;
}

.phase .school-presence.has-schedule {
    grid-template-columns: minmax(0, 1fr) 20px 20px;
}

.module-header .presence-defaults-toggle,
.phase .presence-defaults-toggle {
    width: 30px;
    min-width: 30px;
    height: 30px;
    min-height: 30px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 999px;
    background: #ffffff;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 70%, var(--ink));
    font-size: 0.74rem;
    font-weight: 430;
    opacity: 0.78;
    box-shadow: none;
}

.module-header .school-schedule-toggle,
.phase .school-schedule-toggle {
    width: 30px;
    min-width: 30px;
    height: 30px;
    min-height: 30px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 999px;
    background: #ffffff;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 70%, var(--ink));
    font-size: 0.78rem;
    font-weight: 430;
    opacity: 0.78;
    box-shadow: none;
}

.module-header .school-schedule-toggle:hover,
.module-header .school-schedule-toggle[aria-expanded="true"],
.phase .school-schedule-toggle:hover,
.phase .school-schedule-toggle[aria-expanded="true"] {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 10%, #ffffff);
    opacity: 1;
}

.module-header .presence-defaults-toggle:hover,
.module-header .presence-defaults-toggle[aria-expanded="true"],
.phase .presence-defaults-toggle:hover,
.phase .presence-defaults-toggle[aria-expanded="true"] {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 10%, #ffffff);
    opacity: 1;
}

.school-presence {
    display: grid;
    gap: 5px;
}

.school-presence-display {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    min-height: 30px;
    width: 100%;
    min-width: 0;
    border: 1px solid rgba(37, 47, 56, 0.055);
    border-radius: 9px;
    padding: 0 8px;
    background: rgba(255, 255, 255, 0.44);
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink));
    font-size: 0.78rem;
    font-weight: 520;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.68);
}

.presence-panel-wrap {
    display: grid;
    gap: 8px;
    padding: 0 0 8px;
}

.presence-panel-wrap:empty {
    display: none;
}

.presence-panel-wrap .presence-day-form,
.presence-panel-wrap .presence-defaults-form,
.presence-panel-wrap .school-schedule-form {
    width: 100%;
    min-width: 0;
}

.school-presence-display span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.school-presence-display.has-override {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 24%, rgba(37, 47, 56, 0.08));
    background: color-mix(in srgb, var(--member-color, var(--accent)) 11%, #ffffff);
}

.phase .school-presence-display,
.phase .school-presence-display.has-override {
    border-color: transparent;
    border-radius: 0;
    padding: 0;
    min-height: 18px;
    background: transparent;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 34%, #a8b0ba);
    font-size: 0.69rem;
    font-variant-caps: all-small-caps;
    font-weight: 430;
    letter-spacing: 0.045em;
    line-height: 1.35;
    text-transform: lowercase;
    box-shadow: none;
}

.phase .presence-defaults-toggle,
.phase .school-schedule-toggle {
    width: 20px;
    min-width: 20px;
    height: 20px;
    min-height: 20px;
    border-color: transparent;
    background: transparent;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 34%, #a8b0ba);
    font-size: 0.68rem;
    font-weight: 380;
    line-height: 1;
    opacity: 0.82;
}

.phase .presence-defaults-toggle:hover,
.phase .presence-defaults-toggle[aria-expanded="true"],
.phase .school-schedule-toggle:hover,
.phase .school-schedule-toggle[aria-expanded="true"] {
    background: transparent;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 46%, #8f99a6);
}

.presence-day-form,
.presence-defaults-form,
.school-schedule-form {
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.74);
    box-shadow: 0 8px 20px rgba(25, 34, 43, 0.045);
}

.presence-day-form[hidden],
.presence-defaults-form[hidden],
.school-schedule-form[hidden] {
    display: none;
}

.presence-day-form {
    display: grid;
    grid-template-columns: max-content minmax(0, 1fr) minmax(0, 1fr) 30px;
    gap: 6px;
    align-items: center;
    padding: 7px;
}

.presence-day-form:has(.presence-reset-day) {
    grid-template-columns: max-content minmax(0, 1fr) minmax(0, 1fr) 30px 30px;
}

.presence-home-toggle {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    min-width: max-content;
    color: var(--ink-soft);
    font-size: 0.72rem;
    font-weight: 520;
}

.presence-home-toggle input {
    width: 14px;
    min-height: 14px;
    accent-color: color-mix(in srgb, var(--member-color, var(--accent)) 74%, #ffffff);
}

.presence-day-form input[type="time"],
.presence-default-row input[type="time"] {
    min-height: 30px;
    min-width: 0;
    padding: 4px 5px;
    border-color: rgba(37, 47, 56, 0.06);
    border-radius: 9px;
    background: #ffffff;
    font-size: 0.74rem;
}

.presence-day-form input[type="time"]:disabled,
.presence-default-row input[type="time"]:disabled {
    opacity: 0.45;
}

.presence-day-form input[type="time"]:disabled {
    display: none;
}

.presence-save-button,
.presence-reset-day {
    width: 30px;
    min-width: 30px;
    height: 30px;
    min-height: 30px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    background: #ffffff;
    color: var(--ink-soft);
    box-shadow: none;
}

.presence-save-button {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 74%, var(--ink));
}

.presence-defaults-form {
    display: grid;
    gap: 6px;
    padding: 8px;
}

.school-schedule-form {
    display: grid;
    gap: 10px;
    padding: 10px;
}

.school-schedule-form[data-floating="true"] {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 22%, rgba(37, 47, 56, 0.08));
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 24px 64px rgba(25, 34, 43, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

.presence-defaults-head,
.school-schedule-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    color: var(--muted);
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.035em;
    text-transform: uppercase;
}

.presence-defaults-close,
.school-schedule-close {
    width: 24px;
    min-width: 24px;
    height: 24px;
    min-height: 24px;
    border-radius: 999px;
    background: #ffffff;
    color: var(--muted);
    box-shadow: none;
}

.school-schedule-table {
    display: grid;
    grid-template-columns: minmax(168px, 0.92fr) repeat(5, minmax(82px, 1fr));
    gap: 5px;
    align-items: stretch;
}

.schedule-head-cell {
    display: grid;
    min-height: 24px;
    align-items: center;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--muted));
    font-size: 0.68rem;
    font-weight: 620;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.schedule-time-cell {
    display: grid;
    grid-template-columns: 18px minmax(64px, 1fr) minmax(64px, 1fr);
    gap: 4px;
    align-items: center;
}

.schedule-time-cell span {
    color: var(--muted);
    font-size: 0.68rem;
    font-weight: 620;
}

.schedule-time-cell input[type="time"] {
    min-width: 64px;
    padding-inline: 7px;
    font-variant-numeric: tabular-nums;
}

.schedule-time-cell input[type="time"]::-webkit-calendar-picker-indicator {
    display: none;
}

.schedule-time-cell input,
.schedule-subject-cell {
    min-width: 0;
    min-height: 30px;
    border-color: rgba(37, 47, 56, 0.055);
    border-radius: 8px;
    padding: 4px 6px;
    background: #ffffff;
    box-shadow: none;
    font-size: 0.72rem;
}

.schedule-subject-cell {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 3%, #ffffff);
}

.presence-default-row {
    display: grid;
    grid-template-columns: 24px max-content minmax(0, 1fr) minmax(0, 1fr);
    gap: 5px;
    align-items: center;
}

.presence-default-row > span {
    color: var(--ink-soft);
    font-size: 0.72rem;
    font-weight: 650;
}

.presence-save-defaults {
    min-height: 30px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    background: #ffffff;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 74%, var(--ink));
    font-size: 0.76rem;
    font-weight: 520;
    box-shadow: none;
}

.recurring-rule-list[hidden] {
    display: none;
}

.recurring-rule-list {
    display: grid;
    gap: 8px;
    max-height: min(58vh, calc(100dvh - 220px));
    overflow-y: auto;
    overscroll-behavior: contain;
    padding-right: 3px;
    scrollbar-width: thin;
}

.recurring-phase-group {
    display: grid;
    gap: 5px;
}

.recurring-phase-group h4 {
    margin: 2px 0 0;
    color: var(--muted);
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.035em;
    text-transform: uppercase;
}

.empty-series-list {
    display: grid;
    min-height: 34px;
    place-items: center;
    border: 1px dashed rgba(37, 47, 56, 0.08);
    border-radius: 10px;
    color: var(--muted);
    font-size: 0.76rem;
}

.global-deck {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 10px;
    width: 100%;
    margin: 0 auto 18px;
    border: 1px solid rgba(255, 255, 255, 0.46);
    border-radius: 22px;
    padding: 10px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.32), rgba(255, 255, 255, 0.12)),
        rgba(255, 255, 255, 0.2);
    box-shadow: 0 18px 48px rgba(25, 34, 43, 0.045), inset 0 1px 0 rgba(255, 255, 255, 0.56);
}

.top-dashboard {
    display: grid;
    gap: 10px;
    width: 100%;
    margin: 0 auto 18px;
}

.global-module-strip {
    display: grid;
    grid-template-columns: minmax(280px, 1.25fr) minmax(230px, 0.9fr) minmax(260px, 1fr) minmax(260px, 1fr);
    gap: 14px;
    min-width: 0;
}

.global-card {
    display: grid;
    align-content: start;
    gap: 10px;
    min-width: 0;
    border: 1px solid rgba(255, 255, 255, 0.62);
    border-radius: 18px;
    padding: 14px;
    background: rgba(255, 255, 255, 0.48);
    box-shadow: 0 18px 46px rgba(25, 34, 43, 0.055), inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.global-card-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) max-content max-content;
    gap: 8px;
    align-items: center;
}

.global-card h2 {
    margin: 0;
    color: #a8b0ba;
    font-size: 0.69rem;
    font-weight: 520;
    letter-spacing: 0.045em;
    text-transform: uppercase;
}

.global-head-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
    min-height: 0;
    border: 0;
    padding: 0;
    background: transparent;
    color: inherit;
    font: inherit;
    letter-spacing: inherit;
    text-align: left;
    text-transform: inherit;
    box-shadow: none;
    border-radius: 0;
}

.global-head-toggle:hover,
.global-head-toggle[aria-expanded="true"] {
    color: color-mix(in srgb, var(--accent) 58%, var(--ink));
    transform: none;
}

.important-card-head {
    grid-template-columns: minmax(0, 1fr) minmax(0, max-content);
    align-items: center;
}

.day-name-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    max-width: min(46vw, 260px);
    min-width: 28px;
    min-height: 24px;
    border: 0;
    border-radius: 999px;
    padding: 0;
    background: transparent;
    color: #9aa4ae;
    box-shadow: none;
    font-size: 0.74rem;
    font-weight: 700;
    line-height: 1.15;
    text-align: right;
}

.day-name-toggle.has-day-name {
    color: color-mix(in srgb, var(--accent) 82%, var(--ink));
}

.day-name-toggle.has-day-name span {
    letter-spacing: 0.02em;
    line-height: 1.35;
    text-transform: uppercase;
}

.day-name-toggle span {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.day-name-toggle:hover,
.day-name-toggle[aria-expanded="true"] {
    background: transparent;
    color: color-mix(in srgb, var(--accent) 70%, var(--ink));
    transform: none;
}

.day-name-icon {
    width: 16px;
    height: 16px;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.8;
}

.global-card h2 .global-head-toggle.icon-only,
.global-card h2 .global-head-toggle::before,
.global-card h2 .global-head-toggle::after {
    content: none;
    display: none;
}

.family-upgrades-card {
    gap: 6px;
    min-height: 0;
    border-radius: 16px;
    padding-block: 8px 10px;
}

.family-upgrades-card .global-card-head {
    grid-template-columns: minmax(0, 1fr) max-content;
}

.family-upgrade-title-toggle {
    display: inline-flex;
    align-items: center;
    min-height: 0;
    border: 0;
    padding: 0;
    color: inherit;
    background: transparent;
    font: inherit;
    letter-spacing: inherit;
    text-transform: inherit;
    cursor: pointer;
}

.family-upgrade-title-toggle[aria-expanded="true"] {
    color: color-mix(in srgb, var(--accent) 50%, var(--ink));
}

.family-highlight-counters {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 5px;
    min-width: 0;
}

.family-highlight-counter {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    min-height: 20px;
    border: 1px solid rgba(37, 47, 56, 0.055);
    border-radius: 999px;
    padding: 1px 7px;
    background: rgba(255, 255, 255, 0.44);
    color: var(--muted);
    font-size: 0.68rem;
    line-height: 1;
    white-space: nowrap;
}

.family-highlight-counter-icon {
    display: block;
    width: 14px;
    height: 14px;
    flex: 0 0 14px;
    color: var(--muted);
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.7;
}

.family-highlight-counter strong {
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 560;
    font-variant-numeric: tabular-nums;
}

.family-highlight-counter small {
    color: var(--muted);
    font-size: 0.62rem;
    font-weight: 560;
}

.family-upgrade-track {
    position: relative;
    height: 24px;
    overflow: hidden;
    border: 1px solid rgba(37, 47, 56, 0.055);
    border-radius: 999px;
    background:
        linear-gradient(90deg, rgba(108, 161, 126, 0.1), rgba(255, 255, 255, 0.72) 48%, rgba(72, 132, 104, 0.16));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.68);
}

.family-upgrade-fill-lane {
    --family-upgrade-cap: 10px;
    position: absolute;
    inset: 5px;
    overflow: hidden;
    border-radius: 999px;
    z-index: 2;
}

.family-upgrade-segment {
    position: absolute;
    top: 0;
    bottom: 0;
}

.family-upgrade-segment-before {
    left: 0;
    border-radius: 999px;
    background: #cde4d7;
    z-index: 2;
}

.family-upgrade-segment-before.is-single,
.family-upgrade-segment-today.starts-track {
    border-radius: 999px;
}

.family-upgrade-segment-today {
    border-radius: 999px;
    background: #66c59a;
    z-index: 1;
}

.family-upgrade-today-badge {
    display: inline-flex;
    align-items: center;
    min-height: 18px;
    border: 1px solid rgba(86, 185, 141, 0.22);
    border-radius: 999px;
    padding: 0 7px;
    background: rgba(86, 185, 141, 0.08);
    color: #168a5a;
    font-size: 0.65rem;
    font-weight: 560;
    white-space: nowrap;
}

.family-upgrade-mark {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 1px;
    color: var(--muted);
    pointer-events: none;
    z-index: 2;
}

.family-upgrade-mark i {
    position: absolute;
    top: 0;
    left: 0;
    width: 1px;
    height: 100%;
    border-radius: 999px;
    background: rgba(95, 107, 120, 0.34);
}

.family-upgrade-mark.is-reached i {
    background: color-mix(in srgb, #56b98d 72%, rgba(95, 107, 120, 0.22));
}

.family-upgrade-mark.is-label-hidden small {
    display: none;
}

.family-upgrade-mark small {
    position: absolute;
    top: 50%;
    left: 5px;
    max-width: 130px;
    overflow: hidden;
    color: color-mix(in srgb, var(--muted) 82%, var(--ink));
    font-size: 0.64rem;
    line-height: 1;
    text-overflow: ellipsis;
    white-space: nowrap;
    transform: translateY(-50%);
}

.family-upgrade-mark.is-edge-end small {
    right: 5px;
    left: auto;
    text-align: right;
}

.family-upgrade-mark.is-reached small {
    border-radius: 999px;
    padding: 1px 4px;
    background: color-mix(in srgb, #56b98d 72%, rgba(255, 255, 255, 0.28));
    color: #ffffff;
    text-shadow: 0 1px 2px rgba(26, 74, 52, 0.34);
}

.family-upgrade-details {
    display: grid;
    gap: 8px;
    margin-top: 2px;
    border: 1px solid rgba(37, 47, 56, 0.055);
    border-radius: 14px;
    padding: 10px;
    background: color-mix(in srgb, var(--paper) 64%, rgba(255, 255, 255, 0.58));
}

.family-upgrade-details[hidden] {
    display: none;
}

.family-upgrade-stats,
.family-upgrade-modules,
.family-upgrade-milestones {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 12px;
    color: var(--muted);
    font-size: 0.72rem;
}

.family-upgrade-stats span,
.family-upgrade-modules span,
.family-upgrade-milestones span {
    display: inline-flex;
    gap: 4px;
}

.family-upgrade-stats strong,
.family-upgrade-modules strong {
    color: color-mix(in srgb, var(--accent) 45%, var(--ink));
    font-weight: 560;
}

.family-upgrade-milestones strong {
    color: var(--ink);
    font-weight: 560;
}

.family-upgrade-log {
    display: grid;
    gap: 6px;
}

.family-upgrade-log-row {
    display: grid;
    grid-template-columns: minmax(90px, 0.8fr) max-content minmax(0, 1fr);
    gap: 8px;
    align-items: center;
    border: 1px solid rgba(37, 47, 56, 0.055);
    border-radius: 10px;
    padding: 7px 9px;
    color: var(--muted);
    font-size: 0.72rem;
    background: rgba(255, 255, 255, 0.42);
}

.family-upgrade-log-row strong {
    color: var(--ink);
    font-weight: 560;
}

.family-upgrade-log-row small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.family-upgrade-log-edit {
    grid-template-columns: minmax(88px, 0.75fr) 76px minmax(120px, 1fr) max-content max-content max-content;
    gap: 6px;
}

.family-upgrade-redeem-form {
    display: grid;
    grid-template-columns: minmax(160px, 1fr) minmax(120px, 1fr) max-content;
    gap: 7px;
}

.family-upgrade-redeem-form select,
.family-upgrade-redeem-form input {
    min-height: 32px;
    border-radius: 10px;
    font-size: 0.76rem;
}

.family-upgrade-redeem-form button {
    min-height: 32px;
    border-radius: 999px;
    padding: 0 14px;
    font-size: 0.76rem;
}

.day-name-form,
.weather-location-form {
    display: grid;
    gap: 6px;
}

.day-name-form {
    grid-template-columns: minmax(0, 1fr) 30px 30px;
    align-items: center;
}

.day-name-form.is-empty {
    grid-template-columns: minmax(0, 1fr) 30px;
}

.weather-location-form {
    grid-template-columns: minmax(0, 1fr) max-content;
}

.day-name-form[hidden],
.global-info-form[hidden],
.global-misc-form[hidden],
.weather-location-form[hidden] {
    display: none;
}

.day-name-form input,
.weather-location-form input,
.global-info-form input,
.global-info-edit-panel input,
.global-misc-form input,
.global-misc-edit-panel input,
.menu-row-form input {
    min-height: 30px;
    border-color: rgba(37, 47, 56, 0.06);
    border-radius: 10px;
    background: #ffffff;
    box-shadow: none;
    font-size: 0.78rem;
}

.day-name-form button,
.weather-location-form button,
.global-info-form button,
.global-misc-form button,
.menu-row-form button,
.weather-location-toggle,
.global-info-toggle,
.global-misc-toggle {
    width: 30px;
    min-width: 30px;
    height: 30px;
    min-height: 30px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 999px;
    background: #ffffff;
    color: var(--ink-soft);
    box-shadow: none;
}

.weather-location-form .weather-location-reset {
    width: auto;
    min-width: 0;
    padding: 0 10px;
    font-size: 0.74rem;
    font-weight: 520;
}

.global-info-list {
    display: grid;
    gap: 4px;
}

.global-misc-list {
    display: grid;
    gap: 4px;
}

.global-info-row,
.global-misc-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 6px;
    align-items: baseline;
}

.global-info-row small,
.menu-row-form small {
    color: color-mix(in srgb, var(--accent) 76%, var(--ink));
    font-size: 0.72rem;
    font-weight: 650;
}

.global-info-display,
.global-misc-display {
    display: flex;
    align-items: baseline;
    gap: 4px;
    min-width: 0;
}

.global-info-title,
.global-misc-title {
    display: block;
    flex: 1 1 auto;
    min-width: 0;
    min-height: 0;
    border: 0;
    border-radius: 0;
    padding: 0;
    background: transparent;
    color: var(--ink);
    box-shadow: none;
    text-align: left;
}

.global-info-options,
.global-misc-options {
    flex: 0 0 auto;
    width: 20px;
    min-width: 20px;
    height: 20px;
    min-height: 20px;
    border-radius: 8px;
    background: transparent;
    color: var(--muted);
    font-size: 1rem;
    box-shadow: none;
}

.global-info-title span,
.global-misc-title span,
.important-preview-row span {
    overflow-wrap: anywhere;
    font-size: 0.82rem;
}

.global-info-row.highlighted .global-info-title,
.important-preview-row.highlighted span {
    font-weight: 650;
}

.global-info-edit-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 30px 30px 30px 30px;
    gap: 6px;
    align-items: center;
}

.global-info-edit-panel[hidden],
.global-misc-edit-panel[hidden] {
    display: none;
}

.global-info-edit-panel .task-option,
.global-info-edit-panel button,
.global-misc-edit-panel button {
    width: 30px;
    min-width: 30px;
    height: 30px;
    min-height: 30px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    background: #ffffff;
    color: var(--ink-soft);
    box-shadow: none;
}

.global-info-edit-panel .task-save-button,
.global-info-edit-panel .task-delete-button,
.global-misc-edit-panel .task-save-button,
.global-misc-edit-panel .task-delete-button {
    padding: 0;
    font-size: 0.78rem;
}

.global-misc-edit-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 30px 30px;
    gap: 6px;
    align-items: center;
}

.global-info-form,
.global-misc-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 30px;
    gap: 6px;
    align-items: center;
}

.global-muted {
    margin: 0;
    color: var(--ink-soft);
    font-size: 0.8rem;
}

.weather-chart-wrap {
    width: 100%;
    min-width: 0;
}

.weather-chart {
    display: block;
    width: 100%;
    height: auto;
    max-height: 122px;
}

.weather-grid {
    stroke: rgba(37, 47, 56, 0.08);
    stroke-width: 1;
}

.weather-temp-line {
    fill: none;
    stroke: rgba(93, 105, 114, 0.72);
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2.2;
}

.weather-temp-dots circle {
    fill: #ffffff;
    stroke: rgba(93, 105, 114, 0.72);
    stroke-width: 1.8;
}

.weather-temp-dots circle.is-uv-low {
    fill: #8fb79c;
    stroke: rgba(76, 128, 91, 0.78);
}

.weather-temp-dots circle.is-uv-medium {
    fill: #dfcf80;
    stroke: rgba(164, 139, 57, 0.78);
}

.weather-temp-dots circle.is-uv-high {
    fill: #d7897f;
    stroke: rgba(158, 86, 78, 0.78);
}

.weather-temp-dots circle.is-uv-unknown {
    fill: #f4f6f7;
    stroke: rgba(93, 105, 114, 0.42);
}

.weather-point-symbol {
    overflow: visible;
}

.weather-point-symbol .weather-day-icon {
    width: 20px;
    height: 20px;
    color: color-mix(in srgb, var(--ink-soft) 86%, var(--ink));
    stroke-width: 1.75;
}

.weather-rain-bars rect {
    fill: rgba(77, 145, 202, 0.38);
}

.weather-day-symbol {
    display: inline-flex;
    width: 20px;
    height: 20px;
    margin-left: 5px;
    align-items: center;
    justify-content: center;
    color: color-mix(in srgb, var(--accent) 72%, var(--ink));
    vertical-align: -2px;
}

.weather-card h2 {
    display: flex;
    min-width: 0;
    align-items: center;
    gap: 5px;
}

.weather-card .weather-day-symbol {
    margin-left: 0;
}

.weather-range {
    color: var(--ink-soft);
    font-size: 0.68rem;
    font-weight: 520;
    letter-spacing: 0;
    text-transform: none;
    white-space: nowrap;
}

.weather-day-icon {
    width: 19px;
    height: 19px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.7;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.weather-day-icon-rain,
.weather-day-icon-snow,
.weather-day-icon-storm {
    color: currentColor;
}

.weather-hour-labels text,
.weather-max-label,
.weather-min-label {
    fill: var(--muted);
    font-size: 0.64rem;
    font-weight: 520;
    text-anchor: middle;
}

.weather-max-label,
.weather-min-label {
    fill: var(--ink-soft);
    text-anchor: middle;
    font-weight: 680;
}

.weather-hour-labels text.is-uv-low {
    fill: #7fad8d;
    font-weight: 720;
}

.weather-hour-labels text.is-uv-medium {
    fill: #d4bb32;
    font-weight: 760;
}

.weather-hour-labels text.is-uv-high {
    fill: #d86658;
    font-weight: 780;
}

.menu-preview {
    display: grid;
    gap: 6px;
}

.menu-row-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 6px;
    align-items: center;
}

.menu-preview-row {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: 6px;
    align-items: baseline;
    font-size: 0.8rem;
}

.important-preview {
    display: grid;
    gap: 6px;
}

.important-preview-row {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: 6px;
    align-items: baseline;
    font-size: 0.8rem;
}

.menu-preview-row small,
.important-preview-row small {
    color: var(--ink);
    font-size: 0.72rem;
    font-weight: 430;
}

.menu-preview-row small.is-urgent,
.important-preview-row small.is-urgent {
    color: var(--danger);
    font-weight: 520;
}

.menu-preview-row span,
.important-preview-row span {
    overflow-wrap: anywhere;
}

.composer-phase-choice {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 760px) {
    .member-column {
        padding: 18px;
    }

    .person-module {
        padding: 14px;
    }

    .task-edit-panel {
        grid-template-columns: minmax(0, 1fr) 34px;
    }

    .task-rule-button,
    .task-option,
    .task-move-tomorrow,
    .task-delete-button {
        grid-column: auto;
    }

    .task-edit-panel .task-rule-button,
    .task-edit-panel input[name="title"] {
        grid-column: 1 / -1;
    }

    .presence-day-form,
    .presence-day-form:has(.presence-reset-day) {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    }

    .presence-home-toggle {
        grid-column: 1 / -1;
    }

    .presence-save-button,
    .presence-reset-day {
        grid-column: auto;
    }

    .presence-default-row {
        grid-template-columns: 22px max-content 1fr 1fr;
    }

    .module-actions {
        grid-template-columns: 30px;
    }

    .module-header .school-presence,
    .phase .school-presence {
        grid-template-columns: minmax(92px, max-content) 30px;
    }

    .module-header .school-presence.has-schedule,
    .phase .school-presence.has-schedule {
        grid-template-columns: minmax(92px, max-content) 30px 30px;
    }

    .school-schedule-table {
        grid-template-columns: minmax(168px, 0.9fr) repeat(5, minmax(82px, 1fr));
    }

    .composer-phase-choice {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Compact configuration panel in the hub/bento style. */
.settings-panel {
    top: 72px;
    right: 24px;
    width: min(760px, calc(100vw - 32px));
    max-height: calc(100vh - 92px);
    overflow: auto;
    gap: 12px;
    padding: 18px;
    border: 1px solid rgba(255, 255, 255, 0.68);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 22px 60px rgba(25, 34, 43, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

.share-panel {
    position: fixed;
    inset: 0;
    z-index: 40;
    display: grid;
    place-items: center;
    padding: 18px;
    background: rgba(30, 38, 45, 0.18);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.share-panel[hidden] {
    display: none;
}

.share-card {
    position: relative;
    display: grid;
    justify-items: center;
    gap: 12px;
    width: min(330px, calc(100vw - 36px));
    border: 1px solid rgba(255, 255, 255, 0.72);
    border-radius: 18px;
    padding: 18px;
    background: rgba(255, 255, 255, 0.9);
    box-shadow: 0 24px 70px rgba(25, 34, 43, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

.share-close {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 30px;
    min-width: 30px;
    height: 30px;
    min-height: 30px;
    border-radius: 999px;
    background: #ffffff;
    color: var(--muted);
    box-shadow: none;
}

.share-card img {
    width: 260px;
    max-width: 100%;
    height: auto;
    border-radius: 10px;
    background: #ffffff;
}

.share-card p {
    width: 100%;
    margin: 0;
    overflow-wrap: anywhere;
    color: var(--ink-soft);
    font-size: 0.78rem;
    text-align: center;
}


.settings-head {
    align-items: center;
}

.settings-head .eyebrow {
    color: var(--accent);
}

.settings-head h2 {
    font-size: 1.08rem;
    font-weight: 520;
}

.settings-section {
    gap: 10px;
    padding: 12px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.64);
    box-shadow: none;
}

.settings-section h3 {
    font-size: 0.82rem;
    font-weight: 520;
}

.settings-inline-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 42px max-content;
    gap: 8px;
    align-items: center;
}

.settings-inline-form.share-url-form {
    grid-template-columns: minmax(0, 1fr) max-content;
}

.settings-inline-form.dark-mode-settings-form {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr) repeat(2, 86px) repeat(4, 70px) minmax(170px, 1fr) minmax(116px, 0.45fr) max-content;
}

.settings-inline-form.family-upgrade-settings-form {
    grid-template-columns: minmax(0, 1fr) 96px 132px max-content;
}

.settings-inline-form.family-upgrade-create-form {
    grid-template-columns: minmax(0, 1fr) 96px 132px max-content;
}

.settings-inline-form.family-upgrade-adjustment-form {
    grid-template-columns: 96px 132px minmax(0, 1fr) max-content;
}

.settings-inline-form.family-highlight-counters-form {
    grid-template-columns: minmax(88px, 1fr) minmax(88px, 1fr) max-content;
}

.settings-inline-form.family-highlight-counters-form input {
    min-width: 88px;
}

.settings-inline-form.completion-warning-settings-form {
    grid-template-columns: repeat(3, minmax(136px, 1fr)) max-content;
}

.completion-warning-field {
    display: grid;
    grid-template-columns: minmax(60px, 1fr) minmax(64px, 72px) auto;
    gap: 7px;
    align-items: center;
    min-width: 136px;
    min-height: 34px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    padding: 0 10px;
    background: #ffffff;
    color: var(--ink-soft);
    font-size: 0.76rem;
    font-weight: 520;
}

.completion-warning-field input {
    width: 100%;
    min-width: 64px;
    min-height: 28px;
    border: 0 !important;
    padding: 0 2px;
    background: transparent !important;
    box-shadow: none !important;
    text-align: right;
}

.completion-warning-field em {
    color: var(--muted);
    font-style: normal;
    font-size: 0.74rem;
}

.settings-inline-form input,
.settings-inline-form select,
.member-edit-row input {
    min-height: 34px;
}

.settings-inline-form select {
    min-width: 0;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    padding: 0 12px;
    background: #ffffff;
    color: var(--ink-soft);
    font: inherit;
    font-size: 0.78rem;
}

.settings-inline-form input[type="color"],
.member-edit-row input[type="color"] {
    width: 42px;
    height: 34px;
    min-height: 34px;
    padding: 3px;
}

.appearance-range {
    display: grid;
    grid-template-columns: auto minmax(80px, 1fr) 38px;
    gap: 8px;
    align-items: center;
    min-width: 0;
    min-height: 34px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    padding: 0 10px;
    background: #ffffff;
    color: var(--ink-soft);
    font-size: 0.74rem;
    font-weight: 520;
}

.appearance-range input[type="range"] {
    min-height: 0;
    padding: 0;
    box-shadow: none;
    accent-color: var(--accent);
}

.appearance-range output {
    color: var(--muted);
    font-size: 0.72rem;
    text-align: right;
}

.appearance-color {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 38px;
    gap: 8px;
    align-items: center;
    min-width: 0;
    min-height: 34px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    padding: 0 8px 0 10px;
    background: #ffffff;
    color: var(--ink-soft);
    font-size: 0.74rem;
    font-weight: 520;
}

.appearance-color input[type="color"] {
    width: 34px;
    height: 28px;
    min-height: 28px;
    padding: 2px;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.settings-inline-form button,
.member-edit-row button,
.member-edit-actions button {
    min-height: 34px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    padding: 0 12px;
    background: #ffffff;
    color: var(--ink-soft);
    font-size: 0.78rem;
    font-weight: 430;
    box-shadow: none;
}

.family-upgrade-admin-list,
.family-upgrade-transaction-list,
.donation-admin-list {
    display: grid;
    gap: 7px;
}

.donation-admin-card {
    display: grid;
    gap: 8px;
    border: 1px solid rgba(37, 47, 56, 0.055);
    border-radius: 12px;
    padding: 8px;
    background: rgba(255, 255, 255, 0.44);
}

.donation-admin-balance-form,
.donation-admin-log-row {
    display: grid;
    grid-template-columns: minmax(76px, 1fr) 96px max-content;
    gap: 6px;
    align-items: center;
}

.donation-admin-balance-form input {
    min-height: 30px;
    border-color: rgba(37, 47, 56, 0.06);
    border-radius: 9px;
    background: #ffffff;
    font-size: 0.74rem;
}

.donation-admin-log {
    display: grid;
    gap: 5px;
}

.donation-admin-log-row {
    grid-template-columns: 88px 72px minmax(0, 1fr) 26px;
    color: var(--muted);
    font-size: 0.72rem;
}

.donation-admin-log-row strong {
    color: var(--ink-soft);
}

.donation-admin-log-row.is-credit strong {
    color: #25855c;
}

.donation-admin-log-row small {
    overflow-wrap: anywhere;
}

.settings-muted {
    margin: 0;
    color: var(--muted);
    font-size: 0.76rem;
}

.family-upgrade-admin-row,
.family-upgrade-transaction-row {
    display: grid;
    gap: 7px;
    align-items: center;
    min-width: 0;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 12px;
    padding: 7px;
    background: rgba(255, 255, 255, 0.52);
}

.family-upgrade-admin-row {
    grid-template-columns: minmax(0, 1fr) 86px 132px max-content 30px;
}

.family-upgrade-transaction-row {
    grid-template-columns: minmax(70px, 0.8fr) 76px 132px minmax(0, 1fr) 86px max-content 30px;
}

.family-upgrade-details .family-upgrade-transaction-row {
    grid-template-columns: minmax(76px, 0.75fr) 72px 118px minmax(100px, 1fr) 82px max-content 30px;
}

.family-upgrade-admin-row input,
.family-upgrade-transaction-row input {
    min-width: 0;
    min-height: 32px;
    border-radius: 10px;
    font-size: 0.76rem;
}

.family-upgrade-admin-row span,
.family-upgrade-transaction-row span,
.family-upgrade-transaction-row small {
    overflow: hidden;
    color: var(--muted);
    font-size: 0.72rem;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.family-upgrade-transaction-row.is-spend span {
    color: #9d6a5f;
}

.family-upgrade-admin-row button,
.family-upgrade-transaction-row button {
    min-height: 30px;
    border-radius: 999px;
    padding: 0 10px;
    font-size: 0.74rem;
}

.family-upgrade-delete,
.family-upgrade-transaction-delete {
    width: 30px;
    min-width: 30px;
    padding: 0;
}

.member-editor-list {
    gap: 8px;
    max-height: min(46vh, 420px);
}

.member-edit-form {
    gap: 7px;
    padding: 9px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.58);
    box-shadow: none;
}

.member-edit-form.is-hidden {
    opacity: 0.62;
    background: rgba(245, 247, 248, 0.76);
}

.member-edit-row {
    display: grid;
    grid-template-columns: 14px minmax(0, 1fr) 42px max-content;
    gap: 8px;
    align-items: center;
}

.member-status-dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--member-color);
}

.member-avatar-editor {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) max-content;
    gap: 8px;
    align-items: center;
}

.member-avatar-preview {
    width: 38px;
    height: 38px;
    border: 2px solid rgba(255, 255, 255, 0.86);
    border-radius: 999px;
    background:
        radial-gradient(circle at 32% 24%, rgba(255, 255, 255, 0.92) 0 17%, transparent 18%),
        color-mix(in srgb, var(--member-color, var(--accent)) 22%, #ffffff);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.84), 0 4px 10px rgba(37, 47, 56, 0.08);
}

.member-avatar-preview[data-has-avatar="true"] {
    background:
        var(--member-avatar-image) center / 78% 78% no-repeat,
        radial-gradient(circle at 32% 24%, rgba(255, 255, 255, 0.92) 0 17%, transparent 18%),
        color-mix(in srgb, var(--member-color, var(--accent)) 22%, #ffffff);
}

.member-avatar-file-label {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    padding: 0 12px;
    background: #ffffff;
    color: var(--ink-soft);
    font-size: 0.78rem;
    cursor: pointer;
}

.member-avatar-file-label input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
}

.member-avatar-remove {
    min-height: 34px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    padding: 0 12px;
    background: #ffffff;
    color: var(--ink-soft);
    font-size: 0.78rem;
}

.member-avatar-remove:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.member-edit-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    color: var(--muted);
    font-size: 0.76rem;
}

.media-settings-editor {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
    align-items: center;
}

.media-settings-editor .member-school-toggle,
.media-settings-editor .effective-date-field,
.media-settings-editor button {
    grid-column: 1 / -1;
}

.media-settings-editor input,
.media-settings-editor textarea {
    min-width: 0;
    min-height: 30px;
    border-color: rgba(37, 47, 56, 0.06);
    border-radius: 9px;
    background: #ffffff;
    box-shadow: none;
    font-size: 0.74rem;
}

.media-settings-editor textarea {
    grid-column: 1 / -1;
    min-height: 54px;
    resize: vertical;
    padding: 8px 10px;
    font-family: inherit;
    line-height: 1.25;
}

.media-settings-editor button {
    min-height: 30px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    padding: 0 10px;
    background: #ffffff;
    color: var(--ink-soft);
    font-size: 0.74rem;
    box-shadow: none;
}

.media-category-list {
    display: grid;
    grid-column: 1 / -1;
    gap: 7px;
}

.media-category-editor {
    display: grid;
    grid-template-columns: minmax(72px, 0.8fr) minmax(0, 1.15fr) minmax(58px, 0.55fr) 26px;
    gap: 6px;
    align-items: center;
    border: 1px solid rgba(37, 47, 56, 0.055);
    border-radius: 11px;
    padding: 7px;
    background: rgba(255, 255, 255, 0.46);
}

.media-category-editor input,
.media-category-editor select {
    min-width: 0;
    min-height: 30px;
    border-color: rgba(37, 47, 56, 0.06);
    border-radius: 9px;
    background: #ffffff;
    box-shadow: none;
    font-size: 0.72rem;
}

.media-category-editor [name="mediaCategoryDescription"] {
    grid-column: 1 / 4;
}

.media-category-editor .media-category-remove {
    grid-row: 1 / 3;
    grid-column: 4;
    width: 26px;
    min-width: 26px;
    min-height: 26px;
    align-self: stretch;
    padding: 0;
    color: var(--danger);
}

.media-category-add {
    justify-self: start;
}

.member-school-toggle {
    display: inline-flex;
    grid-auto-flow: column;
    align-items: center;
    gap: 6px;
    min-height: 30px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 999px;
    padding: 0 10px;
    background: #ffffff;
    color: var(--ink-soft);
    font-size: 0.76rem;
    font-weight: 430;
}

.member-school-toggle input {
    width: 14px;
    min-height: 14px;
    accent-color: var(--accent);
}

.member-delete-button {
    color: var(--danger) !important;
}

.danger-zone p {
    font-size: 0.78rem;
}

.color-presets {
    display: none;
}

@media (max-width: 760px) {
    .settings-panel {
        top: 72px;
        right: 10px;
        left: 10px;
        width: auto;
        max-height: calc(100vh - 84px);
    }

    .settings-inline-form,
    .member-edit-row {
        grid-template-columns: minmax(0, 1fr) 42px;
    }

    .settings-inline-form.dark-mode-settings-form {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .settings-inline-form.family-upgrade-settings-form,
    .settings-inline-form.family-upgrade-create-form,
    .settings-inline-form.family-upgrade-adjustment-form,
    .settings-inline-form.family-highlight-counters-form,
    .settings-inline-form.completion-warning-settings-form {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .settings-inline-form.dark-mode-settings-form select,
    .settings-inline-form.dark-mode-settings-form button,
    .settings-inline-form.family-upgrade-settings-form button,
    .settings-inline-form.family-upgrade-create-form button,
    .settings-inline-form.family-upgrade-adjustment-form button,
    .settings-inline-form.family-highlight-counters-form button,
    .settings-inline-form.completion-warning-settings-form button {
        grid-column: 1 / -1;
    }

    .completion-warning-field {
        min-width: 0;
    }

    .settings-inline-form button,
    .member-edit-row button {
        grid-column: 1 / -1;
    }

    .member-status-dot {
        display: none;
    }

    .member-avatar-editor {
        grid-template-columns: 42px minmax(0, 1fr);
    }

    .member-avatar-remove {
        grid-column: 1 / -1;
        justify-self: start;
    }

    .member-edit-actions {
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .family-upgrade-admin-row,
    .family-upgrade-transaction-row,
    .donation-admin-balance-form,
    .donation-admin-log-row {
        grid-template-columns: minmax(0, 1fr) 72px 30px;
    }

    .family-upgrade-admin-row button[type="submit"],
    .family-upgrade-transaction-row button[type="submit"],
    .family-upgrade-transaction-row span,
    .family-upgrade-transaction-row small,
    .family-upgrade-transaction-row input[name="note"],
    .donation-admin-balance-form strong,
    .donation-admin-balance-form button,
    .donation-admin-log-row small {
        grid-column: 1 / -1;
    }

}

@media (max-width: 760px) {
    html,
    body {
        min-height: 100%;
    }

    body {
        min-height: 100dvh;
    }

    .app-shell {
        min-height: 100dvh;
        padding: 10px 0 0;
        background: linear-gradient(135deg, #f7f8f9 0%, #f2f5f6 54%, #f7f3f2 100%);
    }

    .topbar {
        position: relative;
        top: auto;
        z-index: 8;
        display: grid;
        grid-template-columns: 30px minmax(0, 1fr);
        gap: 8px 10px;
        align-items: center;
        min-height: 0;
        margin: 0 10px 8px;
        padding: 8px 10px;
        border-radius: 16px;
        background: rgba(255, 255, 255, 0.66);
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
    }

    .topbar h1 {
        width: 30px;
        min-width: 30px;
        overflow: hidden;
        gap: 0;
        font-size: 0;
        line-height: 1.1;
    }

    .topbar h1::before,
    .logout-link,
    .settings-toggle.icon-only,
    .share-toggle.icon-only,
    .home-guide-toggle.icon-only,
    .fullscreen-toggle.icon-only {
        width: 30px;
        min-width: 30px;
        height: 30px;
        min-height: 30px;
    }

    .topbar-actions {
        display: grid;
        grid-auto-flow: column;
        grid-auto-columns: max-content;
        gap: 6px;
        align-items: center;
        justify-content: end;
        min-width: 0;
        max-width: 100%;
        overflow: hidden;
    }

    .user-badge {
        min-height: 30px;
        max-width: 66px;
        overflow: hidden;
        padding: 0 6px;
        text-overflow: ellipsis;
    }

    .daybar {
        display: grid;
        grid-column: 1 / -1;
        grid-template-columns: minmax(0, 1fr) 30px max-content 30px 30px;
        gap: 7px;
        align-items: center;
        justify-self: stretch;
        width: 100%;
        margin: 0;
    }

    .daybar .icon-button {
        width: 30px;
        min-width: 30px;
        height: 30px;
        min-height: 30px;
        font-size: 1rem;
    }

    .date-display-text {
        width: 100%;
        min-width: 0;
        min-height: 30px;
        padding-inline: 6px;
        font-size: 0.9rem;
        text-align: left;
    }

    .today-compact {
        min-height: 30px;
        padding-inline: 4px;
    }

    .board {
        display: flex;
        min-height: calc(100dvh - 112px);
        gap: 12px;
        max-width: 100vw;
        padding: 0 10px 18px;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        scrollbar-width: none;
    }

    .global-deck {
        display: grid;
        gap: 8px;
        max-width: calc(100vw - 20px);
        margin: 0 10px 12px;
        padding: 8px;
        overflow: visible;
        border-radius: 18px;
        scroll-snap-type: none;
    }

    .global-deck::-webkit-scrollbar {
        display: none;
    }

    .global-module-strip {
        display: flex;
        gap: 10px;
        width: calc(100vw - 36px);
        margin: 0;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        scrollbar-width: none;
    }

    .global-module-strip::-webkit-scrollbar {
        display: none;
    }

    .global-card {
        flex: 0 0 calc(100vw - 36px);
        scroll-snap-align: center;
        padding: 12px;
    }

    .family-upgrades-card {
        width: 100%;
        min-height: 0;
        padding: 10px 12px;
    }

    .family-upgrades-card .global-card-head {
        align-items: center;
    }

    .family-highlight-counter {
        padding-inline: 5px;
    }

    .family-upgrade-track {
        height: 22px;
    }

    .family-upgrade-mark small {
        max-width: 92px;
        font-size: 0.6rem;
    }

    .global-card-head {
        align-items: start;
    }

    .important-card-head {
        grid-template-columns: minmax(0, 1fr) minmax(0, max-content);
        align-items: center;
    }

    .day-name-toggle {
        max-width: min(52vw, 220px);
    }

    .family-upgrade-redeem-form {
        grid-template-columns: 1fr;
    }

    .global-info-form {
        grid-template-columns: minmax(0, 1fr) 30px;
    }

    .menu-row-form {
        grid-template-columns: minmax(0, 1fr);
    }

    .member-column {
        flex: 0 0 calc(100vw - 20px);
        min-height: calc(100dvh - 130px);
        scroll-snap-align: center;
        padding: 16px;
    }

    .member-header {
        position: static;
        z-index: auto;
        margin: 0 0 10px;
        padding: 0;
        border: 0;
        border-radius: 0;
        background: transparent;
        box-shadow: none;
    }

    .member-title h2 {
        font-size: 1rem;
        line-height: 1.15;
    }

    .flagged-list {
        margin-top: 6px;
    }

    .flagged-chip {
        min-height: 0;
        grid-template-columns: 86px minmax(0, 1fr);
    }

    .person-module {
        padding: 12px;
    }
}

@media (min-width: 761px) {
    .top-dashboard > .topbar {
        position: static;
        top: auto;
        display: grid;
        grid-template-columns: max-content max-content max-content;
        gap: 10px;
        align-items: center;
        width: auto;
        max-width: none;
        min-height: 0;
        margin: 0;
        padding: 12px;
    }

    .topbar-brand {
        gap: 0;
    }

    .topbar-brand h1 {
        position: absolute;
        width: 1px;
        height: 1px;
        overflow: hidden;
        clip: rect(0 0 0 0);
        white-space: nowrap;
    }

    .top-dashboard > .global-deck {
        margin: 0;
    }

    .board {
        display: grid;
        grid-template-columns: repeat(var(--member-count, 5), minmax(0, 1fr));
        gap: clamp(7px, 0.9vw, 14px);
        align-items: start;
        overflow: visible;
        max-width: 100%;
        min-width: 0;
        width: 100%;
        scroll-snap-type: none;
    }

    .global-deck {
        grid-template-columns: minmax(0, 1fr);
        max-width: 100%;
        overflow: visible;
    }

    .global-module-strip {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        max-width: 100%;
        overflow: visible;
    }

    .member-column {
        flex: initial;
        min-width: 0;
        max-width: none;
        width: auto;
        padding-inline: clamp(8px, 1vw, 18px);
    }

    .person-module {
        overflow: visible;
    }

    .presence-defaults-form,
    .presence-day-form,
    .person-task-form {
        width: 100%;
        max-width: none;
    }
}

@container (max-width: 285px) {
    .appointments-module .module-header {
        display: flex;
        grid-template-columns: none;
    }

    .appointments-module .module-actions {
        flex: 0 0 30px;
        justify-self: end;
    }

    .presence-day-form,
    .presence-day-form:has(.presence-reset-day) {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) 30px;
        align-items: center;
    }

    .presence-day-form:has(.presence-reset-day) {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) 30px 30px;
    }

    .presence-day-form .presence-home-toggle {
        grid-column: 1 / -1;
    }

    .presence-day-form input[type="time"]:first-of-type {
        grid-column: 1;
    }

    .presence-day-form input[type="time"]:last-of-type {
        grid-column: 2;
    }

    .presence-day-form .presence-save-button {
        grid-column: 3;
    }

    .presence-day-form .presence-reset-day {
        grid-column: 4;
    }

    .presence-default-row {
        grid-template-columns: 24px minmax(0, 1fr) minmax(0, 1fr);
    }

    .presence-default-row > span {
        grid-column: 1;
    }

    .presence-default-row .presence-home-toggle {
        grid-column: 2 / -1;
    }

    .presence-default-row input[type="time"] {
        min-width: 0;
        width: 100%;
    }

    .presence-default-row > input[type="time"]:first-of-type {
        grid-column: 2;
    }

    .presence-default-row > input[type="time"]:last-of-type {
        grid-column: 3;
    }

    .presence-home-toggle {
        min-width: 0;
    }
}

.presence-day-form:has(.presence-home-toggle input:checked) {
    grid-template-columns: minmax(0, 1fr) 30px;
}

.presence-day-form:has(.presence-home-toggle input:checked):has(.presence-reset-day) {
    grid-template-columns: minmax(0, 1fr) 30px 30px;
}

.presence-day-form:has(.presence-home-toggle input:checked) .presence-home-toggle {
    grid-column: 1;
}

.presence-day-form:has(.presence-home-toggle input:checked) .presence-save-button {
    grid-column: 2;
}

.presence-day-form:has(.presence-home-toggle input:checked) .presence-reset-day {
    grid-column: 3;
}

.phase-presence-wrap .presence-day-form:has(.presence-home-toggle input:checked),
.phase-presence-wrap .presence-day-form:has(.presence-home-toggle input:checked):has(.presence-reset-day) {
    grid-template-columns: minmax(0, 1fr) 30px;
}

.phase-presence-wrap .presence-day-form:has(.presence-home-toggle input:checked) .presence-reset-day {
    grid-column: 2;
    grid-row: 2;
}

@media (max-width: 760px) {
    .board {
        display: flex;
        overflow-x: auto;
        overflow-y: visible;
    }
}

.presence-day-form input[type="time"],
.presence-default-row input[type="time"] {
    width: 100%;
    min-width: 0;
    text-align: center;
}

.phase-choice span,
.composer-tab {
    min-height: 32px;
    padding-block: 5px;
    white-space: normal;
    line-height: 1.12;
}

.task-item {
    border-width: 1px;
}

@container (max-width: 250px) {
    .person-module {
        padding: 10px;
    }

    .phase {
        border-width: 1px;
        padding: 5px 6px;
    }

    .task-item {
        min-height: 28px;
        border-radius: 8px;
        padding-block: 2px;
    }

    .task-title {
        line-height: 1.14;
    }

    .composer-tabs,
    .composer-phase-choice {
        gap: 4px;
    }

    .phase-choice span,
    .composer-tab,
    .weekday-choice span {
        padding-inline: 5px;
        font-size: 0.7rem;
    }
}

/* Editing surfaces need to survive narrow desktop/tablet columns. */
.person-task-form[data-floating="true"],
.task-edit-panel[data-floating="true"],
.school-schedule-form[data-floating="true"] {
    overflow: visible;
    overscroll-behavior: contain;
    border: 1px solid color-mix(in srgb, var(--member-color, var(--accent)) 20%, rgba(37, 47, 56, 0.08));
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.82)),
        color-mix(in srgb, var(--member-color, var(--accent)) 7%, #ffffff);
    box-shadow: 0 22px 60px rgba(25, 34, 43, 0.13), inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

.person-task-form[hidden],
.task-edit-panel[hidden] {
    display: none !important;
}

.composer-tabs {
    grid-template-columns: repeat(auto-fit, minmax(88px, 1fr));
}

.composer-phase-choice {
    grid-template-columns: repeat(auto-fit, minmax(76px, 1fr));
}

.recurring-edit-form .phase-choice-group {
    grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
}

.weekday-choice-group {
    grid-template-columns: repeat(auto-fit, minmax(32px, 1fr));
}

.phase-choice span,
.composer-tab,
.weekday-choice span {
    overflow: visible;
    min-width: 0;
    text-overflow: clip;
    white-space: normal;
    overflow-wrap: anywhere;
}

.task-edit-panel {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 7px;
}

.task-edit-panel input[name="title"] {
    flex: 1 1 168px;
}

.task-edit-panel .task-rule-button,
.task-edit-panel .task-option,
.task-edit-panel .task-move-tomorrow,
.task-edit-panel .task-save-button,
.task-edit-panel .task-delete-button {
    flex: 0 0 32px;
}

@container (max-width: 260px) {
    .composer-tabs {
        grid-template-columns: repeat(auto-fit, minmax(82px, 1fr));
    }

    .composer-phase-choice {
        grid-template-columns: repeat(auto-fit, minmax(70px, 1fr));
    }

    .composer-row {
        grid-template-columns: minmax(0, 1fr) 36px;
    }
}

.app-shell.is-swipe-layout .member-tabs {
    position: sticky;
    top: 72px;
    z-index: 9;
    display: flex;
    gap: 8px;
    max-width: 100%;
    margin: 0 0 10px;
    padding: 0 4px 8px;
    overflow-x: auto;
    scrollbar-width: none;
}

.app-shell.is-swipe-layout .member-tabs::-webkit-scrollbar,
.app-shell.is-swipe-layout .board::-webkit-scrollbar {
    display: none;
}

.app-shell.is-swipe-layout .member-tab {
    flex: 0 0 auto;
    min-height: 34px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 999px;
    padding: 0 12px;
    background: #ffffff;
    color: var(--ink-soft);
    font-size: 0.8rem;
    font-weight: 430;
    box-shadow: none;
}

.app-shell.is-swipe-layout .member-tab.active {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 12%, #ffffff);
    color: color-mix(in srgb, var(--member-color, var(--accent)) 64%, var(--ink));
}

.app-shell.is-swipe-layout .board {
    display: flex;
    gap: 14px;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
}

.app-shell.is-swipe-layout .member-column {
    flex: 0 0 min(360px, calc(100vw - 38px));
    max-width: min(360px, calc(100vw - 38px));
    min-width: min(320px, calc(100vw - 38px));
    scroll-snap-align: center;
}

.reflection-module {
    display: grid;
    gap: 6px;
    padding-top: 2px;
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 10%, var(--stroke));
    transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

.family-question-module,
.reflection-donation-module {
    display: grid;
    gap: 7px;
    padding-top: 2px;
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 18%, var(--stroke));
}

.family-question-reroll-form {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-top: 2px;
}

.family-question-reroll-form button {
    width: 34px;
    min-width: 34px;
    height: 30px;
    min-height: 30px;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 40%, var(--muted));
    font-size: 0.7rem;
    font-weight: 520;
    box-shadow: none;
}

.family-question-reroll-form button:hover {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 8%, rgba(255, 255, 255, 0.7));
    color: color-mix(in srgb, var(--member-color, var(--accent)) 64%, var(--ink));
}

.family-level-icon {
    display: inline-flex;
    align-items: flex-end;
    justify-content: center;
    gap: 2px;
    width: 18px;
    height: 14px;
}

.family-level-icon i {
    display: block;
    width: 4px;
    border-radius: 999px;
    background: currentColor;
    opacity: 0.22;
}

.family-level-icon i:nth-child(1) {
    height: 6px;
}

.family-level-icon i:nth-child(2) {
    height: 10px;
}

.family-level-icon i:nth-child(3) {
    height: 14px;
}

.family-question-level-toggle[data-level="1"] .family-level-icon i:nth-child(1),
.family-question-level-toggle[data-level="2"] .family-level-icon i:nth-child(-n + 2),
.family-question-level-toggle[data-level="3"] .family-level-icon i {
    opacity: 0.86;
}

.family-question-reroll-button {
    font-size: 0.9rem !important;
}

.reflection-donation-module .reflection-donation {
    margin: 0;
    border: 0;
    padding: 0;
    background: transparent;
}

.reflection-donation-module {
    min-height: 54px;
    align-content: center;
}

.reflection-donation-module .reflection-donation-toggle {
    min-height: 28px;
    align-items: center;
}

.person-module.is-complete,
.appointments-module.is-empty-complete {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 48%, rgba(37, 47, 56, 0.08));
    background: color-mix(in srgb, var(--member-color, var(--accent)) 9%, rgba(255, 255, 255, 0.62));
    box-shadow:
        inset 0 0 0 1px color-mix(in srgb, var(--member-color, var(--accent)) 26%, transparent),
        0 18px 48px rgba(72, 92, 108, 0.08),
        var(--inner-light);
}

.person-module.earns-family-point,
.person-module.is-complete.earns-family-point,
.appointments-module.is-empty-complete.earns-family-point {
    border-width: 2px;
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 68%, rgba(255, 255, 255, 0.18));
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--member-color, var(--accent)) 28%, rgba(255, 255, 255, 0.2)),
        inset 0 0 0 1px color-mix(in srgb, var(--member-color, var(--accent)) 38%, rgba(255, 255, 255, 0.28)),
        0 18px 48px rgba(72, 92, 108, 0.08),
        var(--inner-light);
}

.goals-module {
    display: grid;
    gap: 7px;
    padding-top: 2px;
}

.appointments-module {
    display: grid;
    gap: 7px;
    padding-top: 2px;
}

.appointments-module .module-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    align-items: center;
    gap: 0;
    margin-top: 0;
    padding-bottom: 0;
}

.appointment-title-toggle {
    min-width: 0;
    width: fit-content;
    max-width: 100%;
    border: 0;
    border-radius: 0;
    padding: 0;
    background: transparent;
    color: #a8b0ba;
    font-size: 0.69rem;
    font-weight: 520;
    letter-spacing: 0.045em;
    line-height: 1.2;
    text-align: left;
    text-transform: uppercase;
    box-shadow: none;
}

.appointment-title-toggle:hover,
.appointment-title-toggle[aria-expanded="true"] {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 68%, var(--ink));
    transform: none;
}

.appointments-module .phase-grid {
    margin-top: 0;
    padding-top: 0;
}

.goals-header {
    padding-bottom: 0;
    grid-template-columns: minmax(0, 1fr);
}

.goal-title-toggle {
    min-width: 0;
    width: fit-content;
    max-width: 100%;
    border: 0;
    border-radius: 0;
    padding: 0;
    background: transparent;
    color: #a8b0ba;
    font-size: 0.69rem;
    font-weight: 520;
    letter-spacing: 0.045em;
    line-height: 1.2;
    text-align: left;
    text-transform: uppercase;
    box-shadow: none;
}

.goal-title-toggle:hover,
.goal-title-toggle[aria-expanded="true"] {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 68%, var(--ink));
    transform: none;
}

.goal-list {
    display: grid;
    gap: 6px;
}

.goal-item {
    display: grid;
    grid-template-columns: 26px minmax(0, 1fr) 26px;
    gap: 7px;
    align-items: center;
    min-width: 0;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 12px;
    padding: 7px 8px;
    background: rgba(255, 255, 255, 0.48);
}

.goal-status-toggle,
.goal-edit-toggle,
.goal-form button {
    width: 26px;
    min-width: 26px;
    height: 26px;
    min-height: 26px;
    border: 1px solid rgba(37, 47, 56, 0.055);
    border-radius: 999px;
    padding: 0;
    background: #ffffff;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 64%, var(--ink));
    font-size: 0.74rem;
    box-shadow: none;
}

.goal-item.tried .goal-status-toggle {
    border-style: dashed;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 14%, #ffffff);
}

.goal-item.done .goal-status-toggle {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 28%, #ffffff);
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 36%, rgba(37, 47, 56, 0.08));
}

.goal-main {
    display: grid;
    gap: 5px;
    min-width: 0;
}

.goal-main > span {
    overflow-wrap: anywhere;
    color: var(--ink-soft);
    font-size: 0.76rem;
    line-height: 1.2;
}

.goal-history {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 3px;
    max-width: 88px;
}

.goal-history i {
    display: block;
    width: 8px;
    height: 8px;
    border: 1px solid rgba(37, 47, 56, 0.12);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
}

.goal-history i.tried {
    border-style: dashed;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 18%, #ffffff);
}

.goal-history i.done {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 46%, rgba(37, 47, 56, 0.08));
    background: color-mix(in srgb, var(--member-color, var(--accent)) 62%, #ffffff);
}

.media-module {
    display: grid;
    gap: 7px;
    align-content: start;
    padding-top: 2px;
}

.media-module.is-locked {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 48%, rgba(37, 47, 56, 0.08));
}

.media-detail-toggle {
    display: inline-grid;
    width: auto;
    min-width: 26px;
    height: 24px;
    min-height: 24px;
    place-items: center;
    border: 1px solid rgba(37, 47, 56, 0.045);
    border-radius: 999px;
    padding: 0 7px;
    background: #ffffff;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink));
    font-size: 0.74rem;
    font-weight: 520;
    box-shadow: none;
}

.media-detail-toggle > svg {
    pointer-events: none;
}

.media-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 0;
    border-bottom: 0;
    background: transparent;
}

.media-title-toggle {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    min-width: 0;
    min-height: 0;
    border: 0;
    border-radius: 0;
    padding: 0;
    background: transparent;
    color: #a8b0ba;
    font-size: 0.69rem;
    font-weight: 520;
    letter-spacing: 0.045em;
    line-height: 1.05;
    text-align: left;
    text-transform: uppercase;
    box-shadow: none;
}

.media-title-toggle:hover {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 58%, var(--ink));
    transform: none;
}

.media-title-shield {
    width: 13px;
    height: 13px;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.65;
}

.media-shield-icon {
    width: 14px;
    height: 14px;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.75;
}

.media-detail-toggle[aria-pressed="true"] {
    border-color: rgba(37, 47, 56, 0.045);
    background: rgba(255, 255, 255, 0.62);
    color: color-mix(in srgb, var(--member-color, var(--accent)) 68%, var(--ink));
}

.media-module.is-locked .media-detail-toggle {
    border-color: rgba(37, 47, 56, 0.045);
    background: rgba(255, 255, 255, 0.64);
}

.media-start-note {
    margin: 0;
    color: var(--muted);
    font-size: 0.78rem;
}

.media-overview {
    display: grid;
    gap: 6px;
    border: 1px solid rgba(37, 47, 56, 0.055);
    border-radius: 14px;
    padding: 8px 9px 7px;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--member-color, var(--accent)) 5%, rgba(255, 255, 255, 0.82)), rgba(255, 255, 255, 0.46));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.66);
}

.media-balance {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
    align-items: center;
    width: 100%;
    justify-self: stretch;
    margin-top: 0;
}

.media-week-history {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 3px;
    width: min(88px, 100%);
    flex: 0 0 auto;
    justify-self: end;
}

.media-week-history i {
    display: block;
    width: 8px;
    height: 8px;
    border: 1px solid rgba(37, 47, 56, 0.12);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
}

.media-week-history i.good {
    border-color: rgba(90, 132, 104, 0.26);
    background: rgba(90, 132, 104, 0.58);
}

.media-week-history i.good-soft {
    border-color: rgba(90, 132, 104, 0.16);
    background: rgba(90, 132, 104, 0.22);
}

.media-week-history i.neutral {
    border-color: rgba(37, 47, 56, 0.1);
    background: rgba(255, 255, 255, 0.88);
}

.media-week-history i.debt-soft {
    border-color: rgba(152, 103, 102, 0.16);
    background: rgba(152, 103, 102, 0.22);
}

.media-week-history i.debt {
    border-color: rgba(152, 103, 102, 0.26);
    background: rgba(152, 103, 102, 0.58);
}

.media-scale {
    position: relative;
    min-width: 0;
    height: 20px;
    margin-bottom: 2px;
    border-radius: 999px;
    background:
        linear-gradient(90deg,
            rgba(152, 103, 102, 0.24) 0%,
            rgba(152, 103, 102, 0.11) 31%,
            rgba(255, 255, 255, 0.78) 49%,
            rgba(255, 255, 255, 0.78) 51%,
            rgba(90, 132, 104, 0.11) 69%,
            rgba(90, 132, 104, 0.24) 100%),
        rgba(255, 255, 255, 0.58);
    box-shadow: inset 0 1px 2px rgba(25, 34, 43, 0.08);
}

.media-scale::before {
    content: none;
}

.media-scale::after {
    position: absolute;
    top: 3px;
    bottom: 3px;
    left: 50%;
    width: 1px;
    background: rgba(37, 47, 56, 0.16);
    content: "";
}

.media-balance-pill {
    position: absolute;
    z-index: 2;
    top: 50%;
    left: clamp(26px, var(--media-pos, 50%), calc(100% - 26px));
    min-width: 34px;
    border: 1px solid rgba(255, 255, 255, 0.72);
    border-radius: 999px;
    padding: 1px 5px 2px;
    background: rgba(255, 255, 255, 0.78);
    font-size: 0.68rem;
    font-weight: 650;
    line-height: 1.2;
    text-align: center;
    white-space: nowrap;
    box-shadow: 0 4px 12px rgba(25, 34, 43, 0.075);
    transform: translate(-50%, -50%);
}

.media-balance-pill.is-debt {
    border-color: rgba(152, 103, 102, 0.16);
    color: #986766;
}

.media-balance-pill.is-credit {
    border-color: rgba(90, 132, 104, 0.16);
    color: #5a8468;
}

.media-balance-pill.is-neutral {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 16%, rgba(37, 47, 56, 0.06));
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink-soft));
}

.media-module.is-limit-left .media-balance-pill {
    left: 0;
    border-color: rgba(152, 103, 102, 0.55);
    box-shadow:
        0 0 0 1px rgba(152, 103, 102, 0.16),
        0 4px 12px rgba(25, 34, 43, 0.075);
    transform: translate(0, -50%);
}

.media-module.is-limit-right .media-balance-pill {
    left: 100%;
    border-color: rgba(90, 132, 104, 0.55);
    box-shadow:
        0 0 0 1px rgba(90, 132, 104, 0.16),
        0 4px 12px rgba(25, 34, 43, 0.075);
    transform: translate(-100%, -50%);
}

.media-summary {
    justify-content: center;
    display: flex;
    flex-wrap: wrap;
    gap: 4px 7px;
    color: var(--muted);
    font-size: 0.7rem;
}

.media-summary .media-chip {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    min-height: 20px;
    border: 1px solid rgba(37, 47, 56, 0.045);
    border-radius: 999px;
    padding: 1px 6px;
    background: rgba(255, 255, 255, 0.48);
}

.media-module.is-day-over .media-chip.is-counted.has-minutes {
    border-color: rgba(152, 103, 102, 0.2);
    background: rgba(152, 103, 102, 0.09);
    color: #986766;
}

.media-summary .media-detail-toggle {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 58%, var(--ink));
}

.media-summary .media-category-icon {
    width: 13px;
    height: 13px;
    stroke-width: 1.75;
}

.media-summary em {
    font-style: normal;
}

.media-form {
    display: grid;
    gap: 9px;
}

.media-form[hidden] {
    display: none;
}

.media-fields {
    display: grid;
    grid-template-columns: 1fr;
    gap: 7px;
}

.media-time-field {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(86px, max-content);
    gap: 8px;
    align-items: center;
    min-width: 0;
    border: 1px solid rgba(37, 47, 56, 0.055);
    border-radius: 13px;
    padding: 9px 10px;
    background: rgba(255, 255, 255, 0.54);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.64);
}

.media-time-info {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1px;
    align-items: center;
    min-width: 0;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 64%, var(--ink));
}

.media-field-title {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    min-width: 0;
}

.media-field-title em {
    border: 1px solid rgba(37, 47, 56, 0.055);
    border-radius: 999px;
    padding: 1px 5px;
    background: rgba(255, 255, 255, 0.58);
    color: color-mix(in srgb, var(--member-color, var(--accent)) 60%, var(--muted));
    font-size: 0.66rem;
    font-style: normal;
    font-weight: 560;
    line-height: 1.1;
    white-space: nowrap;
}

.media-time-info strong {
    color: var(--ink-soft);
    font-size: 0.76rem;
    font-weight: 620;
    line-height: 1.05;
}

.media-time-info small {
    color: var(--muted);
    font-size: 0.68rem;
    line-height: 1.15;
    overflow-wrap: anywhere;
    white-space: normal;
}

.media-bonus-description {
    display: block;
    margin: 0;
    color: var(--muted);
    font-size: 0.68rem;
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.media-bonus-description p {
    margin: 0;
}

.media-bonus-description ul {
    display: grid;
    gap: 2px;
    margin: 0;
    padding-left: 14px;
}

.media-bonus-description li {
    margin: 0;
}

.media-time-field label {
    display: grid;
    grid-template-columns: 14px minmax(48px, 1fr);
    align-items: center;
    min-width: 0;
    gap: 4px;
    color: var(--muted);
    font-size: 0.72rem;
}

.media-duration-stepper {
    display: grid;
    grid-template-columns: minmax(48px, 1fr) 22px;
    align-items: stretch;
    justify-self: end;
    min-width: 86px;
    overflow: hidden;
    border: 1px solid rgba(37, 47, 56, 0.055);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.66);
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.media-duration-stepper output {
    display: grid;
    min-height: 38px;
    place-items: center;
    padding: 0 8px;
    font-size: 0.78rem;
    font-weight: 620;
    font-variant-numeric: tabular-nums;
    line-height: 1;
    white-space: nowrap;
}

.media-step-buttons {
    display: grid;
    grid-template-rows: 1fr 1fr;
    border-left: 1px solid rgba(37, 47, 56, 0.055);
}

.media-step-button {
    display: grid;
    width: 22px;
    min-width: 22px;
    min-height: 19px;
    border: 0;
    border-radius: 0;
    padding: 0;
    place-items: center;
    background: rgba(255, 255, 255, 0.28);
    color: var(--muted);
    font-size: 0.68rem;
    font-weight: 620;
    line-height: 1;
    box-shadow: none;
    touch-action: none;
    user-select: none;
    -webkit-user-select: none;
}

.media-step-button::before {
    width: 0;
    height: 0;
    border-right: 4px solid transparent;
    border-left: 4px solid transparent;
    content: "";
}

.media-step-button[data-media-step="5"]::before {
    border-bottom: 5px solid currentColor;
}

.media-step-button[data-media-step="-5"]::before {
    border-top: 5px solid currentColor;
}

.media-step-button + .media-step-button {
    border-top: 1px solid rgba(37, 47, 56, 0.055);
}

.media-step-button:hover:not(:disabled) {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 10%, #ffffff);
    color: color-mix(in srgb, var(--member-color, var(--accent)) 68%, var(--ink));
}

.media-step-button:disabled {
    opacity: 0.42;
}

.media-time-field input {
    min-width: 0;
    min-height: 36px;
    border-color: rgba(37, 47, 56, 0.06);
    border-radius: 9px;
    padding: 4px 4px 4px 8px;
    background: #ffffff;
    box-shadow: none;
    font-size: 0.86rem;
    text-align: center;
}

.media-category-icon {
    width: 17px;
    height: 17px;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.75;
}

.media-category-icon {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink));
}

.media-time-field input[readonly] {
    color: var(--muted);
    background: rgba(255, 255, 255, 0.48);
}

.media-bonus-readonly {
    grid-template-columns: minmax(0, 1fr);
}

.media-bonus-readonly .media-time-info {
    grid-column: 1 / -1;
    width: 100%;
    max-width: none;
}

.media-bonus-readonly .media-bonus-description,
.media-bonus-readonly small {
    width: 100%;
    max-width: none;
}

@container (max-width: 285px) {
    .media-time-field {
        grid-template-columns: minmax(0, 1fr) max-content;
    }

    .media-time-info {
        grid-column: 1 / -1;
    }

    .media-bonus-readonly {
        grid-template-columns: minmax(0, 1fr);
    }

    .media-bonus-readonly .media-time-info,
    .media-bonus-readonly .media-bonus-description,
    .media-bonus-readonly small {
        grid-column: 1 / -1;
        width: 100%;
        max-width: none;
    }
}

.media-form-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.media-help {
    display: none;
    flex: 1 1 auto;
    color: var(--muted);
    font-size: 0.72rem;
}

.media-help summary {
    cursor: pointer;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink));
}

.media-help p {
    margin: 6px 0 0;
    line-height: 1.35;
}

.media-lock-toggle {
    display: inline-flex;
    grid-auto-flow: column;
    align-items: center;
    gap: 5px;
    color: var(--ink-soft);
    font-size: 0.72rem;
}

.media-lock-toggle input {
    width: 14px;
    min-height: 14px;
    accent-color: color-mix(in srgb, var(--member-color, var(--accent)) 74%, #ffffff);
}

.goal-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 26px;
    gap: 6px;
    align-items: center;
}

.goal-edit-form {
    grid-column: 1 / -1;
    grid-template-columns: minmax(0, 1fr) 26px 26px;
}

.goal-form .effective-date-field {
    grid-column: 1 / -1;
}

.goal-form[hidden] {
    display: none;
}

.goal-form input {
    min-height: 32px;
    border-radius: 10px;
    font-size: 0.76rem;
}

.reflection-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) max-content;
    align-items: center;
    padding-bottom: 0;
}

.reflection-actions {
    display: flex;
    align-items: center;
    align-self: center;
    gap: 0;
    justify-self: end;
    min-width: 0;
    min-height: 0;
}

.reflection-done {
    display: inline-grid;
    width: 24px;
    height: 24px;
    border: 1px solid color-mix(in srgb, var(--member-color, var(--accent)) 34%, rgba(37, 47, 56, 0.08));
    border-radius: 999px;
    place-items: center;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 18%, #ffffff);
    color: color-mix(in srgb, var(--member-color, var(--accent)) 78%, var(--ink));
    font-size: 0.78rem;
    font-weight: 650;
    line-height: 1;
    box-shadow: none;
}

.reflection-done.is-empty {
    display: none;
}

.mood-toggle {
    width: 42px;
    min-width: 42px;
    height: 42px;
    min-height: 42px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 12px;
    background: #ffffff;
    color: var(--ink-soft);
    font-size: 1.35rem;
    box-shadow: none;
}

.reflection-mood-row {
    display: grid;
    grid-template-columns: max-content minmax(0, 1fr);
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0 0 3px;
}

.reflection-mood-row::after {
    content: "\1F326\FE0F  Nicht jeder Tag muss perfekt sein. Mal wächst du, mal ruhst du - beides bist du. Sei du selbst. Du bist geliebt.";
    color: #8f9aa6;
    font-size: 0.68rem;
    font-style: italic;
    font-weight: 430;
    line-height: 1.25;
}

.reflection-note {
    display: none;
}

.mood-menu {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: center;
    padding: 8px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.72);
}

.mood-menu[hidden] {
    display: none;
}

.mood-choice {
    width: 38px;
    min-width: 38px;
    height: 38px;
    min-height: 38px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 10px;
    padding: 0;
    background: #ffffff;
    font-size: 1.2rem;
    box-shadow: none;
}

.mood-custom {
    flex: 1 1 132px;
    display: grid;
    gap: 4px;
    min-width: 0;
}

.mood-custom span {
    color: var(--muted);
    font-size: 0.66rem;
}

.mood-custom input {
    min-height: 38px;
    border-radius: 10px;
    font-size: 1.2rem;
    text-align: center;
}

.reflection-form {
    display: grid;
    gap: 7px;
}

.reflection-prompt,
.reflection-support-prompt {
    display: grid;
    gap: 4px;
    min-width: 0;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 12px;
    padding: 8px 10px;
    background: rgba(255, 255, 255, 0.48);
    transition: border-color 140ms ease, background 140ms ease, box-shadow 140ms ease;
}

.reflection-card-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) max-content;
    align-items: center;
    gap: 8px;
}

.reflection-card-actions {
    display: flex;
    align-items: center;
    gap: 4px;
}

.reflection-prompt > span {
    color: #9da7b2;
    font-size: 0.68rem;
    font-weight: 430;
    line-height: 1.2;
}

.reflection-prompt small,
.reflection-support-prompt small {
    color: #a8b0ba;
    font-size: 0.66rem;
    font-weight: 520;
    letter-spacing: 0.045em;
    line-height: 1;
    text-transform: uppercase;
}

.reflection-item-toggle,
.reflection-write-toggle {
    width: 26px;
    min-width: 26px;
    height: 26px;
    min-height: 26px;
    border-radius: 999px;
    border: 1px solid rgba(37, 47, 56, 0.055);
    background: #ffffff;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, var(--ink));
    font-size: 0.74rem;
    box-shadow: none;
}

.reflection-item-toggle[aria-pressed="false"] {
    border: 1px solid rgba(37, 47, 56, 0.1);
    background: rgba(255, 255, 255, 0.68);
    color: transparent;
}

.reflection-write-toggle {
    color: #9da7b2;
}

.reflection-item-toggle[aria-pressed="true"] {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 28%, #ffffff);
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 36%, rgba(37, 47, 56, 0.08));
    color: color-mix(in srgb, var(--member-color, var(--accent)) 72%, var(--ink));
}

.reflection-prompt em,
.reflection-support-prompt em {
    color: inherit;
    font: inherit;
    font-style: normal;
    opacity: 0.78;
}

.reflection-prompt > span em {
    opacity: 0.68;
}

.reflection-category {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: inherit;
    font: inherit;
    font-weight: inherit;
    letter-spacing: 0;
    text-transform: none;
}

.reflection-category-icon {
    display: inline-block;
    width: 1em;
    min-width: 1em;
    height: 1em;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 70%, var(--ink));
    fill: none;
    stroke: currentColor;
    stroke-width: 1.85;
    stroke-linecap: round;
    stroke-linejoin: round;
    line-height: 1;
    transform: translateY(-0.02em);
    transform-origin: center;
}

.reflection-heading-separator {
    opacity: 0.72;
}

.reflection-support-prompt p {
    margin: 0;
    color: #9da7b2;
    font-size: 0.72rem;
    line-height: 1.22;
}

.reflection-support-prompt em {
    line-height: inherit;
}

textarea {
    width: 100%;
    min-height: 54px;
    resize: vertical;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 10px;
    padding: 8px 10px;
    background: #ffffff;
    color: var(--ink);
    font: inherit;
    font-size: 0.78rem;
    line-height: 1.25;
    overflow: hidden;
    box-shadow: none;
}

.reflection-prompt textarea {
    resize: none;
}

.reflection-answer-panel[hidden] {
    display: none;
}

.reflection-prompt textarea::placeholder {
    color: #b1bbc4;
    font-size: 0.68rem;
    line-height: 1.2;
    opacity: 0.62;
}

.reflection-donation {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
    margin-top: 2px;
    padding: 8px;
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.58);
}

@container (max-width: 270px) {
    .reflection-module {
        gap: 5px;
    }

    .reflection-mood-row {
        grid-template-columns: 34px minmax(0, 1fr);
        gap: 6px;
        padding-bottom: 1px;
    }

    .mood-toggle {
        width: 34px;
        min-width: 34px;
        height: 34px;
        min-height: 34px;
        border-radius: 10px;
        font-size: 1.08rem;
    }

    .reflection-form {
        gap: 6px;
    }

    .reflection-prompt,
    .reflection-support-prompt {
        gap: 3px;
        border-radius: 11px;
        padding: 7px 8px;
    }

    .reflection-card-head {
        gap: 5px;
    }

    .reflection-card-actions {
        gap: 3px;
    }

    .reflection-item-toggle,
    .reflection-write-toggle {
        width: 24px;
        min-width: 24px;
        height: 24px;
        min-height: 24px;
    }
}

.reflection-donation-toggle {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 8px;
    width: 100%;
    min-width: 0;
    min-height: 34px;
    border: 0;
    border-radius: 10px;
    padding: 0;
    background: transparent;
    box-shadow: none;
    text-align: left;
}

.reflection-donation-toggle span {
    color: var(--muted);
    font-size: 0.68rem;
    font-weight: 560;
    letter-spacing: 0.035em;
    text-transform: uppercase;
}

.reflection-donation-toggle strong {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 72%, var(--ink));
    font-size: 0.9rem;
}

.reflection-donation-panel {
    display: grid;
    gap: 8px;
}

.reflection-donation-panel[hidden] {
    display: none;
}

.reflection-donation-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 34px;
    gap: 6px;
}

.reflection-donation-form input,
.reflection-donation-form button {
    min-height: 34px;
}

.reflection-donation-log {
    display: grid;
    gap: 4px;
    border-top: 1px solid rgba(37, 47, 56, 0.06);
    padding-top: 6px;
}

.reflection-donation-log div {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 8px;
    color: var(--ink-soft);
    font-size: 0.72rem;
}

.reflection-donation-log strong {
    color: var(--ink-soft);
    font-weight: 520;
}

.reflection-donation-log p {
    margin: 0;
    color: var(--muted);
    font-size: 0.72rem;
}

.reflection-settings-form {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) max-content;
}

.member-create-form {
    grid-template-columns: minmax(0, 1fr) 72px 42px max-content;
}

.member-edit-row {
    grid-template-columns: 14px minmax(0, 1fr) 72px 42px max-content;
}

.settings-section textarea {
    resize: vertical;
    min-height: 120px;
    font-family: ui-monospace, "Cascadia Code", Consolas, monospace;
}

.settings-section .media-settings-editor textarea {
    min-height: 54px;
    font-family: inherit;
}

.settings-button-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.settings-button-row button,
#backup-export-button {
    min-height: 34px;
    border: 1px solid rgba(37, 47, 56, 0.07);
    border-radius: 999px;
    padding: 0 12px;
    background: #ffffff;
    color: var(--ink-soft);
    font-size: 0.78rem;
    font-weight: 430;
    box-shadow: none;
}

/* Final topbar guide overrides: keep the house as a real button across layout refinements. */
.topbar {
    width: min(100%, 1680px);
    max-width: calc(100vw - 28px);
    border-color: rgba(255, 255, 255, 0.58);
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.74), rgba(255, 255, 255, 0.26)),
        rgba(255, 255, 255, 0.38);
    box-shadow: 0 18px 48px rgba(25, 34, 43, 0.07), inset 0 1px 0 rgba(255, 255, 255, 0.72);
    overflow: hidden;
}

.topbar-brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.topbar-brand .home-guide-toggle.icon-only {
    display: inline-grid;
    place-items: center;
}

.topbar h1::before {
    display: none !important;
    content: none !important;
}

@media (max-width: 760px) {
    .topbar {
        width: calc(100vw - 20px);
        max-width: calc(100vw - 20px);
        margin: 0 auto 8px;
        border-radius: 18px;
        padding: 8px 10px;
        background:
            linear-gradient(145deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.06)),
            rgba(24, 30, 37, 0.9);
        box-shadow: 0 14px 30px rgba(11, 15, 20, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.08);
    }

    .topbar-brand {
        grid-column: 1;
        width: 30px;
        min-width: 30px;
        gap: 0;
    }

    .topbar-brand h1 {
        position: absolute;
        width: 1px;
        height: 1px;
        overflow: hidden;
        clip: rect(0 0 0 0);
        white-space: nowrap;
    }

    .topbar-brand .home-guide-toggle.icon-only {
        width: 30px;
        min-width: 30px;
        height: 30px;
        min-height: 30px;
    }

    .home-guide-panel {
        top: 70px;
        left: 10px;
        width: calc(100vw - 20px);
        max-height: calc(100dvh - 84px);
    }

    .home-guide-card {
        border-radius: 16px;
        padding: 12px;
    }

    .home-guide-table [role="row"] {
        grid-template-columns: 1fr;
        gap: 3px;
    }

    .home-guide-table [role="row"]:first-child {
        display: none;
    }
}

html[data-theme="dark"] {
    color-scheme: dark;
    --bg-a: #11171d;
    --bg-b: #151b22;
    --bg-c: #1b2027;
    --glass: rgba(26, 32, 39, 0.84);
    --glass-strong: rgba(31, 38, 46, 0.94);
    --glass-soft: rgba(25, 31, 38, 0.68);
    --stroke: rgba(255, 255, 255, 0.08);
    --stroke-muted: rgba(255, 255, 255, 0.1);
    --ink: #edf2f5;
    --ink-soft: #b7c1ca;
    --muted: #7f8d99;
    --accent: #8fb4c8;
    --accent-warm: #c49b78;
    --danger: #d08a91;
    --focus: rgba(143, 180, 200, 0.28);
    --glow-a: rgba(83, 111, 124, 0.22);
    --glow-b: rgba(128, 91, 106, 0.16);
    --glow-c: rgba(80, 92, 112, 0.14);
    --ring-a: rgba(255, 255, 255, 0.08);
    --ring-b: rgba(255, 255, 255, 0.06);
    --ring-c: rgba(255, 255, 255, 0.05);
    --shadow: 0 22px 70px rgba(0, 0, 0, 0.34);
    --shadow-soft: 0 12px 34px rgba(0, 0, 0, 0.24);
    --inner-light: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

html[data-theme="dark"][data-skin="sage"] {
    --bg-a: #101a17;
    --bg-b: #141f1b;
    --bg-c: #1a241f;
    --ink: #edf5ef;
    --ink-soft: #b9c8bf;
    --muted: #82928a;
    --accent: #8db8a1;
    --accent-warm: #c4a073;
    --danger: #d18d87;
    --focus: rgba(141, 184, 161, 0.28);
    --glow-a: rgba(86, 137, 107, 0.24);
    --glow-b: rgba(143, 114, 79, 0.14);
    --glow-c: rgba(72, 115, 103, 0.16);
}

html[data-theme="dark"][data-skin="sunrise"] {
    --bg-a: #1c1517;
    --bg-b: #22181c;
    --bg-c: #271e1b;
    --ink: #f5eeee;
    --ink-soft: #ccb8b8;
    --muted: #9a8587;
    --accent: #d39a8f;
    --accent-warm: #d0ad6d;
    --danger: #de909b;
    --focus: rgba(211, 154, 143, 0.26);
    --glow-a: rgba(172, 92, 76, 0.22);
    --glow-b: rgba(143, 78, 112, 0.16);
    --glow-c: rgba(133, 100, 65, 0.14);
}

html[data-theme="dark"][data-skin="lavender"] {
    --bg-a: #151723;
    --bg-b: #191b28;
    --bg-c: #211b29;
    --ink: #f1f0f8;
    --ink-soft: #c0bfd4;
    --muted: #8d8ca3;
    --accent: #a6acd9;
    --accent-warm: #cb9aac;
    --danger: #d48ca3;
    --focus: rgba(166, 172, 217, 0.28);
    --glow-a: rgba(103, 99, 165, 0.24);
    --glow-b: rgba(86, 125, 153, 0.16);
    --glow-c: rgba(132, 81, 122, 0.14);
}

html[data-theme="dark"][data-skin="forest"] {
    --bg-a: #111912;
    --bg-b: #171e15;
    --bg-c: #1f2418;
    --ink: #eef5ee;
    --ink-soft: #bbc9ba;
    --muted: #879485;
    --accent: #82ad8c;
    --accent-warm: #c19c63;
    --danger: #cf8a86;
    --focus: rgba(130, 173, 140, 0.28);
    --glow-a: rgba(74, 129, 82, 0.24);
    --glow-b: rgba(126, 105, 61, 0.16);
    --glow-c: rgba(93, 123, 75, 0.16);
}

html[data-theme="dark"][data-skin="ocean"] {
    --bg-a: #0f181d;
    --bg-b: #121e25;
    --bg-c: #17242b;
    --ink: #edf4f7;
    --ink-soft: #b7c7cf;
    --muted: #81919a;
    --accent: #80bed1;
    --accent-warm: #c79780;
    --danger: #d18891;
    --focus: rgba(128, 190, 209, 0.28);
    --glow-a: rgba(66, 139, 157, 0.24);
    --glow-b: rgba(82, 106, 156, 0.16);
    --glow-c: rgba(103, 130, 93, 0.12);
}

html[data-theme="dark"][data-skin="graphite"] {
    --bg-a: #121517;
    --bg-b: #171a1d;
    --bg-c: #1d2022;
    --ink: #f1f3f4;
    --ink-soft: #bdc3c7;
    --muted: #8a9298;
    --accent: #9aa5ad;
    --accent-warm: #c0957d;
    --danger: #d08a93;
    --focus: rgba(154, 165, 173, 0.28);
    --glow-a: rgba(104, 114, 123, 0.22);
    --glow-b: rgba(139, 107, 87, 0.14);
    --glow-c: rgba(91, 103, 111, 0.14);
}

html[data-theme="dark"][data-skin="glass"] {
    --bg-a: #101821;
    --bg-b: #151c26;
    --bg-c: #1b202b;
    --glass: rgba(26, 34, 43, 0.76);
    --glass-strong: rgba(32, 41, 52, 0.92);
    --glass-soft: rgba(23, 30, 39, 0.62);
    --stroke: rgba(255, 255, 255, 0.1);
    --ink: #eef4f7;
    --ink-soft: #b8c6cf;
    --muted: #82929d;
    --accent: #91c7d8;
    --accent-warm: #d19aa7;
    --focus: rgba(145, 199, 216, 0.28);
    --glow-a: rgba(70, 142, 164, 0.24);
    --glow-b: rgba(139, 83, 119, 0.16);
    --glow-c: rgba(85, 104, 140, 0.14);
    --blur: blur(26px) saturate(1.18);
}

html[data-theme="dark"][data-skin="contrast"] {
    --bg-a: #05080d;
    --bg-b: #0a1018;
    --bg-c: #0c1118;
    --glass: rgba(10, 16, 24, 0.96);
    --glass-strong: rgba(14, 22, 32, 0.98);
    --glass-soft: rgba(10, 16, 24, 0.84);
    --stroke: rgba(255, 255, 255, 0.18);
    --stroke-muted: rgba(255, 255, 255, 0.16);
    --ink: #ffffff;
    --ink-soft: #d5dee8;
    --muted: #a5b3c2;
    --accent: #7eb6ff;
    --accent-warm: #ffbf66;
    --danger: #ff8fa3;
    --focus: rgba(126, 182, 255, 0.34);
    --glow-a: rgba(53, 95, 148, 0.26);
    --glow-b: rgba(133, 88, 43, 0.18);
    --glow-c: rgba(62, 82, 111, 0.18);
}

html[data-theme="dark"][data-skin="kids"] {
    --bg-a: #14151f;
    --bg-b: #111b26;
    --bg-c: #201827;
    --ink: #f4f2fa;
    --ink-soft: #c4c3d5;
    --muted: #8f91a6;
    --accent: #8bbdff;
    --accent-warm: #e4b15a;
    --danger: #e58a98;
    --focus: rgba(139, 189, 255, 0.28);
    --glow-a: rgba(167, 117, 45, 0.18);
    --glow-b: rgba(67, 126, 174, 0.22);
    --glow-c: rgba(121, 79, 151, 0.18);
}

html[data-theme="dark"][data-skin="metal"] {
    --bg-a: #121517;
    --bg-b: #171a1d;
    --bg-c: #1d2022;
    --ink: #f1f3f4;
    --ink-soft: #bdc3c7;
    --muted: #8a9298;
    --accent: #9aa5ad;
    --accent-warm: #c0957d;
    --danger: #d08a93;
    --focus: rgba(154, 165, 173, 0.28);
    --glow-a: rgba(104, 114, 123, 0.22);
    --glow-b: rgba(139, 107, 87, 0.14);
    --glow-c: rgba(91, 103, 111, 0.14);
}

html[data-theme="dark"][data-skin="colorblind"] {
    --bg-a: #0d171d;
    --bg-b: #121c23;
    --bg-c: #171c23;
    --ink: #edf5f7;
    --ink-soft: #b8c8cf;
    --muted: #82929a;
    --accent: #88ccee;
    --accent-warm: #ddcc77;
    --danger: #cc79a7;
    --focus: rgba(136, 204, 238, 0.28);
    --glow-a: rgba(44, 114, 151, 0.24);
    --glow-b: rgba(145, 117, 44, 0.14);
    --glow-c: rgba(80, 113, 91, 0.12);
}

html[data-theme="dark"][data-skin="paper"] {
    --bg-a: #181612;
    --bg-b: #1f1b15;
    --bg-c: #211e18;
    --glass: rgba(32, 28, 21, 0.88);
    --glass-strong: rgba(39, 34, 26, 0.94);
    --glass-soft: rgba(30, 26, 20, 0.68);
    --stroke: rgba(255, 237, 202, 0.09);
    --ink: #f2ede4;
    --ink-soft: #c8bcaa;
    --muted: #928879;
    --accent: #b0bd91;
    --accent-warm: #d0a175;
    --danger: #d28d8a;
    --focus: rgba(176, 189, 145, 0.28);
    --glow-a: rgba(126, 104, 63, 0.18);
    --glow-b: rgba(106, 89, 57, 0.16);
    --glow-c: rgba(86, 113, 69, 0.12);
}

html[data-theme="dark"] body {
    background:
        radial-gradient(circle at 18% 10%, var(--glow-a), transparent 30%),
        radial-gradient(circle at 82% 6%, var(--glow-b), transparent 28%),
        radial-gradient(circle at 76% 88%, var(--glow-c), transparent 34%),
        linear-gradient(135deg, var(--bg-a) 0%, var(--bg-b) 55%, var(--bg-c) 100%);
    color: var(--ink);
}

html[data-theme="dark"] .glass-panel,
html[data-theme="dark"] .login-panel,
html[data-theme="dark"] .topbar,
html[data-theme="dark"] .daybar,
html[data-theme="dark"] .global-deck,
html[data-theme="dark"] .settings-panel,
html[data-theme="dark"] .empty-state,
html[data-theme="dark"] .error-state,
html[data-theme="dark"] .global-card,
html[data-theme="dark"] .share-card,
html[data-theme="dark"] .home-guide-card,
html[data-theme="dark"] .member-column,
html[data-theme="dark"] .person-module,
html[data-theme="dark"] .phase,
html[data-theme="dark"] .task-list,
html[data-theme="dark"] .task-item,
html[data-theme="dark"] .task-edit-panel,
html[data-theme="dark"] .person-task-form,
html[data-theme="dark"] .presence-day-form,
html[data-theme="dark"] .presence-defaults-form,
html[data-theme="dark"] .school-schedule-form,
html[data-theme="dark"] .goal-item,
html[data-theme="dark"] .goal-form,
html[data-theme="dark"] .reflection-prompt,
html[data-theme="dark"] .reflection-support-prompt,
html[data-theme="dark"] .reflection-donation,
html[data-theme="dark"] .media-overview,
html[data-theme="dark"] .media-time-field,
html[data-theme="dark"] .settings-section,
html[data-theme="dark"] .member-edit-form,
html[data-theme="dark"] .media-category-editor,
html[data-theme="dark"] .family-upgrade-admin-row,
html[data-theme="dark"] .family-upgrade-transaction-row,
html[data-theme="dark"] .donation-admin-card {
    border-color: var(--stroke);
    background: color-mix(in srgb, var(--member-color, var(--bg-b)) 5%, rgba(24, 30, 37, 0.86));
    box-shadow: var(--shadow-soft), var(--inner-light);
}

html[data-theme="dark"] .global-card,
html[data-theme="dark"] .global-deck,
html[data-theme="dark"] .settings-panel,
html[data-theme="dark"] .settings-section,
html[data-theme="dark"] .member-edit-form,
html[data-theme="dark"] .share-card,
html[data-theme="dark"] .home-guide-card {
    background: rgba(24, 30, 37, 0.92);
}

html[data-theme="dark"] .member-column {
    background: color-mix(in srgb, var(--member-color, var(--accent)) 9%, rgba(18, 24, 30, 0.9));
}

html[data-theme="dark"] input,
html[data-theme="dark"] textarea,
html[data-theme="dark"] select {
    border-color: rgba(255, 255, 255, 0.09);
    background: rgba(12, 17, 22, 0.72);
    color: var(--ink);
    box-shadow: none;
}

html[data-theme="dark"] input::placeholder,
html[data-theme="dark"] textarea::placeholder {
    color: rgba(183, 193, 202, 0.58);
}

html[data-theme="dark"] .icon-button,
html[data-theme="dark"] .icon-only,
html[data-theme="dark"] .secondary-button,
html[data-theme="dark"] .logout-link,
html[data-theme="dark"] .settings-inline-form button,
html[data-theme="dark"] .settings-button-row button,
html[data-theme="dark"] #backup-export-button,
html[data-theme="dark"] .member-edit-row button,
html[data-theme="dark"] .member-edit-actions button,
html[data-theme="dark"] .media-settings-editor button,
html[data-theme="dark"] .task-edit-panel button,
html[data-theme="dark"] .task-option,
html[data-theme="dark"] .global-info-edit-panel button,
html[data-theme="dark"] .global-misc-edit-panel button,
html[data-theme="dark"] .weather-location-form button,
html[data-theme="dark"] .global-info-toggle,
html[data-theme="dark"] .global-misc-toggle,
html[data-theme="dark"] .reflection-item-toggle,
html[data-theme="dark"] .reflection-write-toggle,
html[data-theme="dark"] .goal-status-toggle,
html[data-theme="dark"] .goal-edit-toggle,
html[data-theme="dark"] .goal-form button,
html[data-theme="dark"] .media-detail-toggle {
    border-color: rgba(255, 255, 255, 0.09);
    background: rgba(28, 35, 43, 0.9);
    color: var(--ink-soft);
    box-shadow: none;
}

html[data-theme="dark"] .day-name-toggle {
    color: rgba(183, 193, 202, 0.72);
}

html[data-theme="dark"] .day-name-toggle.has-day-name,
html[data-theme="dark"] .day-name-toggle:hover,
html[data-theme="dark"] .day-name-toggle[aria-expanded="true"] {
    color: color-mix(in srgb, var(--accent) 82%, #f4fbf8);
}

html[data-theme="dark"] .task-option:has(input:checked),
html[data-theme="dark"] .phase-choice input:checked + span,
html[data-theme="dark"] .weekday-choice input:checked + span,
html[data-theme="dark"] .composer-tab[aria-pressed="true"],
html[data-theme="dark"] .reflection-item-toggle[aria-pressed="true"],
html[data-theme="dark"] .goal-item.done .goal-status-toggle,
html[data-theme="dark"] .goal-item.tried .goal-status-toggle {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 48%, rgba(255, 255, 255, 0.12));
    background: color-mix(in srgb, var(--member-color, var(--accent)) 24%, rgba(28, 35, 43, 0.92));
    color: var(--ink);
}

html[data-theme="dark"] .reflection-item-toggle[aria-pressed="false"] {
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.06);
    color: transparent;
}

html[data-theme="dark"] .global-info-display,
html[data-theme="dark"] .global-misc-display,
html[data-theme="dark"] .media-summary .media-chip,
html[data-theme="dark"] .media-balance-pill,
html[data-theme="dark"] .media-duration-stepper,
html[data-theme="dark"] .family-highlight-counter,
html[data-theme="dark"] .weather-chart-wrap,
html[data-theme="dark"] .reflection-mood-row,
html[data-theme="dark"] .mood-menu,
html[data-theme="dark"] .home-guide-section,
html[data-theme="dark"] .home-guide-table [role="row"] {
    border-color: rgba(255, 255, 255, 0.08);
    background: rgba(12, 17, 22, 0.42);
}

html[data-theme="dark"] .media-step-buttons,
html[data-theme="dark"] .media-step-button + .media-step-button {
    border-color: rgba(255, 255, 255, 0.08);
}

html[data-theme="dark"] .media-step-button {
    background: rgba(255, 255, 255, 0.035);
    color: var(--muted);
}

html[data-theme="dark"] .media-scale {
    background:
        linear-gradient(90deg, rgba(160, 82, 93, 0.28), rgba(255, 255, 255, 0.12) 50%, rgba(91, 145, 122, 0.28)),
        rgba(255, 255, 255, 0.05);
}

html[data-theme="dark"] .family-upgrade-track {
    border-color: rgba(255, 255, 255, 0.08);
    background: linear-gradient(90deg, rgba(91, 145, 122, 0.16), rgba(255, 255, 255, 0.1) 48%, rgba(91, 145, 122, 0.25));
}

html[data-theme="dark"] .family-upgrade-segment-before {
    background: #375849;
}

html[data-theme="dark"] .family-upgrade-segment-today {
    border-left-color: rgba(255, 255, 255, 0.18);
    background: #56c18f;
}

html[data-theme="dark"] .family-upgrade-details,
html[data-theme="dark"] .family-upgrade-log-row {
    border-color: rgba(255, 255, 255, 0.08);
    background: rgba(12, 17, 22, 0.32);
}

html[data-theme="dark"] .task-title,
html[data-theme="dark"] .global-info-title,
html[data-theme="dark"] .global-misc-title,
html[data-theme="dark"] .goal-main > span,
html[data-theme="dark"] .media-time-info strong {
    color: var(--ink);
}

html[data-theme="dark"] .module-header h2,
html[data-theme="dark"] .global-card h2,
html[data-theme="dark"] .settings-section h3,
html[data-theme="dark"] .phase-title h3 {
    color: var(--muted);
}

html[data-theme="dark"] .topbar-actions .user-badge,
html[data-theme="dark"] .today-compact,
html[data-theme="dark"] .global-muted,
html[data-theme="dark"] .media-time-info small,
html[data-theme="dark"] .reflection-note,
html[data-theme="dark"] .reflection-prompt small,
html[data-theme="dark"] .reflection-support-prompt small {
    color: var(--ink-soft);
}

html[data-theme="dark"] .daybar input.is-today,
html[data-theme="dark"] .date-display-text.is-today {
    color: #56b98d;
    font-weight: 540;
}

html[data-theme="dark"] .today-compact.is-today {
    border-color: rgba(86, 185, 141, 0.42);
    color: #56b98d;
}

html[data-theme="dark"] .daybar .icon-button,
html[data-theme="dark"] .daybar .today-compact {
    border-color: rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.045);
    color: var(--ink-soft);
}

html[data-theme="dark"] .school-presence-display {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 34%, rgba(255, 255, 255, 0.1));
    background: color-mix(in srgb, var(--member-color, var(--accent)) 15%, rgba(14, 19, 25, 0.82));
    color: color-mix(in srgb, var(--member-color, var(--accent)) 48%, var(--ink));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

html[data-theme="dark"] .school-presence-display.has-override {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 48%, rgba(255, 255, 255, 0.12));
    background: color-mix(in srgb, var(--member-color, var(--accent)) 22%, rgba(14, 19, 25, 0.86));
}

html[data-theme="dark"] .phase .school-presence-display,
html[data-theme="dark"] .phase .school-presence-display.has-override {
    border-color: transparent;
    background: transparent;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 32%, var(--muted));
}

html[data-theme="dark"] .phase .presence-defaults-toggle,
html[data-theme="dark"] .phase .school-schedule-toggle,
html[data-theme="dark"] .phase .presence-defaults-toggle:hover,
html[data-theme="dark"] .phase .presence-defaults-toggle[aria-expanded="true"],
html[data-theme="dark"] .phase .school-schedule-toggle:hover,
html[data-theme="dark"] .phase .school-schedule-toggle[aria-expanded="true"] {
    border-color: transparent;
    background: transparent;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 32%, var(--muted));
}

html[data-theme="dark"] .person-module.is-complete,
html[data-theme="dark"] .appointments-module.is-empty-complete {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 68%, rgba(255, 255, 255, 0.18));
    background: color-mix(in srgb, var(--member-color, var(--accent)) 13%, rgba(24, 30, 37, 0.9));
    box-shadow:
        inset 0 0 0 1px color-mix(in srgb, var(--member-color, var(--accent)) 42%, transparent),
        0 14px 36px rgba(0, 0, 0, 0.26),
        var(--inner-light);
}

html[data-theme="dark"] .family-point-links path {
    filter: drop-shadow(0 1px 0 rgba(0, 0, 0, 0.32));
}

html[data-theme="dark"] .person-module.earns-family-point,
html[data-theme="dark"] .person-module.is-complete.earns-family-point,
html[data-theme="dark"] .appointments-module.is-empty-complete.earns-family-point {
    border-width: 2px;
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 74%, rgba(255, 255, 255, 0.1));
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--member-color, var(--accent)) 32%, rgba(255, 255, 255, 0.06)),
        inset 0 0 0 1px color-mix(in srgb, var(--member-color, var(--accent)) 48%, rgba(255, 255, 255, 0.08)),
        0 14px 36px rgba(0, 0, 0, 0.26),
        var(--inner-light);
}

html[data-theme="dark"] .share-panel {
    background: rgba(5, 8, 12, 0.62);
}

.member-column .member-title h2,
.member-column .flagged-chip span,
.member-column .flagged-chip small {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 68%, var(--ink));
}

.member-column .flagged-chip small.is-urgent {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 82%, var(--ink));
}

.phase .school-presence-display,
.phase .school-presence-display span {
    font-variant-caps: all-small-caps;
    font-feature-settings: "tnum" 1;
    letter-spacing: 0.055em;
    text-transform: lowercase;
}

/* Final topbar shell: keep the whole navigation as an inset Bento box on every viewport. */
.topbar {
    width: min(1680px, calc(100vw - 64px));
    max-width: calc(100vw - 64px);
    margin: 0 auto 16px;
    border: 1px solid rgba(255, 255, 255, 0.58);
    border-radius: 22px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.3)),
        rgba(255, 255, 255, 0.46);
    box-shadow:
        0 18px 54px rgba(25, 34, 43, 0.09),
        inset 0 1px 0 rgba(255, 255, 255, 0.76);
}

html[data-theme="dark"] .topbar {
    border-color: rgba(255, 255, 255, 0.08);
    background:
        linear-gradient(145deg, rgba(32, 41, 50, 0.96), rgba(18, 24, 31, 0.88)),
        rgba(20, 26, 33, 0.92);
    box-shadow:
        0 18px 54px rgba(0, 0, 0, 0.28),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.topbar-actions .settings-toggle.icon-only {
    display: none;
}

@media (min-width: 761px) {
    .top-dashboard > .topbar {
        position: static;
        width: auto;
        max-width: none;
        margin: 0;
        padding: 10px;
    }

    .top-dashboard > .topbar .daybar {
        gap: 7px;
        padding: 4px;
    }

    .top-dashboard > .topbar .icon-button,
    .top-dashboard > .topbar .logout-link,
    .top-dashboard > .topbar .settings-toggle.icon-only,
    .top-dashboard > .topbar .share-toggle.icon-only,
    .top-dashboard > .topbar .fullscreen-toggle.icon-only,
    .top-dashboard > .topbar .home-guide-toggle.icon-only {
        width: 34px;
        min-width: 34px;
        height: 34px;
        min-height: 34px;
    }

    .top-dashboard > .topbar .topbar-actions {
        gap: 7px;
    }

    .top-dashboard > .topbar .user-badge {
        display: none;
        min-height: 34px;
        padding-inline: 10px;
    }

    html[data-theme="dark"] .topbar-brand .home-guide-toggle.icon-only {
        border-color: rgba(255, 255, 255, 0.16);
        background: rgba(255, 255, 255, 0.08);
        color: var(--muted);
    }

    html[data-theme="dark"] .topbar-brand .home-guide-toggle.icon-only.is-admin-role {
        border-color: rgba(255, 255, 255, 0.16);
        background: rgba(255, 255, 255, 0.08);
        color: var(--muted);
        font-weight: 520;
    }
}

@media (min-width: 1100px) {
    .top-dashboard {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        align-items: stretch;
        gap: 14px;
    }

    .top-dashboard > .topbar {
        display: contents;
    }

    .top-dashboard > .global-deck {
        display: contents;
    }

    .top-dashboard .daybar {
        display: grid;
        grid-template-columns: minmax(0, 1fr) 30px max-content 30px 30px;
        grid-column: 1;
        grid-row: 1;
        align-self: stretch;
        justify-self: stretch;
        width: auto;
        border: 1px solid rgba(255, 255, 255, 0.62);
        border-radius: 18px;
        padding: 10px;
        background: rgba(255, 255, 255, 0.48);
        box-shadow: 0 18px 46px rgba(25, 34, 43, 0.055), inset 0 1px 0 rgba(255, 255, 255, 0.72);
    }

    .top-dashboard .date-display-text {
        justify-self: start;
        overflow: hidden;
        min-width: 0;
        text-overflow: ellipsis;
    }

    .top-dashboard .family-upgrades-card {
        grid-column: 2 / span 2;
        grid-row: 1;
        align-self: stretch;
    }

    .top-dashboard .topbar-brand {
        display: none;
        grid-column: 4;
        grid-row: 1;
        align-self: center;
        justify-self: start;
        padding-left: 10px;
        z-index: 2;
    }

    .top-dashboard .topbar-actions {
        grid-column: 4;
        grid-row: 1;
        align-self: stretch;
        display: flex;
        align-items: center;
        gap: 7px;
        border: 1px solid rgba(255, 255, 255, 0.62);
        border-radius: 18px;
        justify-content: flex-end;
        padding: 10px;
        background: rgba(255, 255, 255, 0.48);
        box-shadow: 0 18px 46px rgba(25, 34, 43, 0.055), inset 0 1px 0 rgba(255, 255, 255, 0.72);
    }

    .top-dashboard .global-module-strip {
        grid-column: 1 / -1;
    }

    html[data-theme="dark"] .top-dashboard .daybar,
    html[data-theme="dark"] .top-dashboard .topbar-actions {
        border-color: rgba(255, 255, 255, 0.08);
        background: rgba(24, 30, 37, 0.92);
        box-shadow: var(--shadow-soft), var(--inner-light);
    }
}

@media (max-width: 760px) {
    .topbar {
        width: calc(100vw - 20px);
        max-width: calc(100vw - 20px);
        margin: 0 auto 8px;
        border-radius: 18px;
    }
}

@media (max-width: 760px) {
    .app-shell {
        padding-top: 6px;
    }

    .top-dashboard {
        gap: 6px;
        margin-bottom: 8px;
    }

    .top-dashboard > .topbar {
        margin-bottom: 4px;
    }

    .global-deck {
        margin-bottom: 8px;
        padding: 7px;
    }

    .board {
        padding-top: 0;
    }
}

html[data-theme="dark"] .goal-item {
    border-color: rgba(255, 255, 255, 0.11);
    background: rgba(13, 18, 24, 0.5);
}

html[data-theme="dark"] .goal-status-toggle {
    border-color: rgba(210, 224, 233, 0.2);
    background: rgba(255, 255, 255, 0.035);
    color: transparent;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.035);
}

html[data-theme="dark"] .goal-item.tried .goal-status-toggle {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 58%, rgba(255, 255, 255, 0.22));
    border-style: dashed;
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--member-color, var(--accent)) 34%, rgba(20, 27, 35, 0.94)) 0 50%, rgba(255, 255, 255, 0.045) 50% 100%);
    color: color-mix(in srgb, var(--member-color, var(--accent)) 76%, #ffffff);
}

html[data-theme="dark"] .goal-item.done .goal-status-toggle {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 70%, rgba(255, 255, 255, 0.24));
    background: color-mix(in srgb, var(--member-color, var(--accent)) 46%, rgba(20, 27, 35, 0.9));
    color: #ffffff;
    box-shadow:
        inset 0 0 0 1px color-mix(in srgb, var(--member-color, var(--accent)) 42%, transparent),
        0 0 0 1px rgba(255, 255, 255, 0.04);
}

html[data-theme="dark"] .goal-history i {
    border-color: rgba(210, 224, 233, 0.22);
    background: rgba(255, 255, 255, 0.045);
}

html[data-theme="dark"] .goal-history i.tried {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 56%, rgba(255, 255, 255, 0.18));
    border-style: dashed;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 30%, rgba(22, 29, 37, 0.88));
}

html[data-theme="dark"] .goal-history i.done {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 70%, rgba(255, 255, 255, 0.22));
    background: color-mix(in srgb, var(--member-color, var(--accent)) 64%, rgba(22, 29, 37, 0.62));
}

.daybar #current-date {
    position: absolute !important;
    width: 1px !important;
    min-width: 1px !important;
    max-width: 1px !important;
    height: 1px !important;
    min-height: 1px !important;
    overflow: hidden !important;
    border: 0 !important;
    padding: 0 !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

.global-card h2 .global-head-toggle,
html[data-theme="dark"] .global-card h2 .global-head-toggle {
    width: auto !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    color: inherit;
    box-shadow: none !important;
}

.date-display-text,
html[data-theme="dark"] .date-display-text {
    background: transparent;
    color: var(--ink-soft);
    font-weight: 430;
    box-shadow: none;
}

.date-display-text.is-today,
html[data-theme="dark"] .date-display-text.is-today {
    color: #168a5a;
    font-weight: 650;
}

.phase .school-presence-display,
.phase .school-presence-display span {
    font-family: "Segoe UI Variable Text", "Segoe UI", "Aptos", ui-sans-serif, system-ui, sans-serif;
    font-size: 0.66rem;
    font-variant-caps: all-small-caps;
    font-variant-numeric: lining-nums tabular-nums;
    font-feature-settings: "smcp" 1, "c2sc" 1, "lnum" 1, "tnum" 1;
    line-height: 1.35;
}

.weather-uv-labels text,
.weather-uv-label {
    fill: color-mix(in srgb, var(--muted) 74%, var(--ink));
    font-size: 0.55rem;
    font-weight: 640;
    text-anchor: middle;
}

.notes-toggle.icon-only {
    width: 34px;
    min-width: 34px;
    height: 34px;
    min-height: 34px;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--muted);
    text-decoration: none;
    box-shadow: none;
    font-size: 0.92rem;
    font-weight: 430;
}

.notes-panel {
    position: fixed;
    top: 72px;
    right: 22px;
    z-index: 80;
    display: block;
    width: min(540px, calc(100vw - 32px));
    padding: 0;
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.notes-panel[hidden] {
    display: none;
}

.notes-card {
    width: 100%;
    max-height: min(76vh, 720px);
    overflow: auto;
    border: 1px solid rgba(255, 255, 255, 0.7);
    border-radius: 22px;
    padding: 18px;
    background: rgba(255, 255, 255, 0.78);
    box-shadow: 0 28px 90px rgba(72, 92, 108, 0.18), var(--inner-light);
}

.notes-head,
.notes-head-actions,
.quick-note-head {
    display: flex;
    align-items: center;
}

.notes-head {
    position: relative;
    justify-content: flex-end;
    gap: 12px;
    margin-bottom: 10px;
}

.notes-head-actions {
    gap: 8px;
}

.notes-list {
    display: grid;
    gap: 12px;
}

.notes-markdown-help {
    position: relative;
    color: var(--ink-soft);
    font-size: 0.72rem;
}

.notes-markdown-help summary {
    display: inline-grid;
    width: 30px;
    height: 30px;
    border: 0;
    border-radius: 999px;
    place-items: center;
    background: transparent;
    cursor: pointer;
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 620;
    list-style: none;
}

.notes-markdown-help summary::-webkit-details-marker {
    display: none;
}

.notes-markdown-help summary::before {
    content: "›";
    transform: rotate(90deg);
}

.notes-markdown-help[open] summary::before {
    transform: rotate(-90deg);
}

.notes-markdown-help div {
    position: absolute;
    top: calc(100% + 8px);
    right: -36px;
    z-index: 20;
    display: grid;
    gap: 5px;
    width: min(340px, calc(100vw - 52px));
    border: 1px solid rgba(37, 47, 56, 0.06);
    border-radius: 12px;
    padding: 10px 12px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 16px 42px rgba(72, 92, 108, 0.12);
}

.notes-markdown-help code {
    border-radius: 6px;
    padding: 1px 4px;
    background: rgba(37, 47, 56, 0.055);
    color: var(--ink);
    font-size: 0.68rem;
}

.quick-note {
    --note-color: #8da9bd;
    display: grid;
    gap: 8px;
    border: 1px solid color-mix(in srgb, var(--note-color) 26%, rgba(37, 47, 56, 0.04));
    border-radius: 14px;
    padding: 12px;
    background:
        linear-gradient(145deg, color-mix(in srgb, var(--note-color) 12%, rgba(255, 255, 255, 0.84)), rgba(255, 255, 255, 0.64));
}

.quick-note:nth-of-type(4n + 1) {
    --note-color: #8fb79c;
}

.quick-note:nth-of-type(4n + 2) {
    --note-color: #8da9bd;
}

.quick-note:nth-of-type(4n + 3) {
    --note-color: #c6a07a;
}

.quick-note:nth-of-type(4n + 4) {
    --note-color: #b995bf;
}

.quick-note-head {
    gap: 8px;
}

.quick-note-head input {
    flex: 1 1 auto;
    min-width: 0;
    border: 0;
    border-bottom: 1px solid rgba(37, 47, 56, 0.08);
    border-radius: 0;
    padding: 5px 0;
    background: transparent;
    color: var(--ink);
    font-size: 0.96rem;
    font-weight: 620;
}

.quick-note-delete {
    width: 30px;
    height: 30px;
    min-width: 30px;
    border: 0;
    background: transparent;
    color: var(--muted);
}

.quick-note-preview,
.quick-note-body {
    width: 100%;
    min-height: 44px;
    border: 1px solid color-mix(in srgb, var(--note-color) 16%, rgba(37, 47, 56, 0.04));
    border-radius: 12px;
    padding: 10px 12px;
    background: rgba(255, 255, 255, 0.72);
    color: var(--ink-soft);
    line-height: 1.42;
}

.quick-note-body {
    overflow: hidden;
    resize: none;
    font: inherit;
}

.quick-note-preview p,
.quick-note-preview ul,
.quick-note-preview h4,
.quick-note-preview h5,
.quick-note-preview h6 {
    margin: 0 0 0.45em;
}

.quick-note-preview p:last-child,
.quick-note-preview ul:last-child {
    margin-bottom: 0;
}

.quick-note-preview ul {
    padding-left: 1.1rem;
}

.quick-note-preview .notes-task-item {
    display: flex;
    align-items: flex-start;
    gap: 0.48rem;
    list-style: none;
    margin-left: -1.1rem;
}

.quick-note-preview .notes-task-box {
    display: inline-grid;
    flex: 0 0 1rem;
    width: 1rem;
    height: 1rem;
    place-items: center;
    border: 1px solid color-mix(in srgb, var(--note-color) 42%, rgba(37, 47, 56, 0.14));
    border-radius: 5px;
    margin-top: 0.1rem;
    background: rgba(255, 255, 255, 0.62);
    color: color-mix(in srgb, var(--note-color) 72%, var(--ink));
    font-size: 0.68rem;
    font-weight: 720;
    line-height: 1;
}

.quick-note-preview .notes-task-item.is-checked > span:last-child {
    color: color-mix(in srgb, var(--note-color) 54%, var(--ink-soft));
    text-decoration: line-through;
    text-decoration-color: color-mix(in srgb, var(--note-color) 50%, transparent);
}

.quick-note-preview table {
    width: 100%;
    border-collapse: collapse;
    margin: 0.2rem 0 0.55rem;
    font-size: 0.92em;
}

.quick-note-preview th,
.quick-note-preview td {
    border-bottom: 1px solid rgba(37, 47, 56, 0.08);
    padding: 0.36rem 0.45rem;
    overflow-wrap: anywhere;
    text-align: left;
    vertical-align: top;
}

.quick-note-preview th {
    color: var(--ink);
    font-weight: 650;
}

.quick-note-preview .is-align-center {
    text-align: center;
}

.quick-note-preview .is-align-right {
    text-align: right;
}

.quick-note-preview code {
    border-radius: 5px;
    padding: 0.08em 0.28em;
    background: rgba(37, 47, 56, 0.06);
    font-size: 0.9em;
}

.notes-empty {
    margin: 0;
    color: var(--muted);
}

html[data-theme="dark"] .notes-card,
html[data-theme="dark"] .quick-note,
html[data-theme="dark"] .quick-note-preview,
html[data-theme="dark"] .quick-note-body {
    border-color: rgba(255, 255, 255, 0.08);
    background: rgba(20, 26, 33, 0.88);
}

html[data-theme="dark"] .quick-note {
    border-color: color-mix(in srgb, var(--note-color) 34%, rgba(255, 255, 255, 0.08));
    background:
        linear-gradient(145deg, color-mix(in srgb, var(--note-color) 18%, rgba(20, 26, 33, 0.92)), rgba(20, 26, 33, 0.84));
}

html[data-theme="dark"] .quick-note-preview,
html[data-theme="dark"] .quick-note-body {
    border-color: color-mix(in srgb, var(--note-color) 22%, rgba(255, 255, 255, 0.08));
    background: rgba(12, 17, 22, 0.5);
}

html[data-theme="dark"] .quick-note-preview .notes-task-box {
    border-color: color-mix(in srgb, var(--note-color) 48%, rgba(255, 255, 255, 0.12));
    background: rgba(255, 255, 255, 0.06);
}

html[data-theme="dark"] .notes-markdown-help code {
    background: rgba(255, 255, 255, 0.07);
    color: var(--ink);
}

html[data-theme="dark"] .notes-markdown-help summary {
    border-color: transparent;
    background: transparent;
}

html[data-theme="dark"] .notes-markdown-help div {
    border-color: rgba(255, 255, 255, 0.08);
    background: rgba(20, 26, 33, 0.96);
}

html[data-theme="dark"] .notes-panel {
    background: transparent;
}

html[data-theme="dark"] .quick-note-preview th,
html[data-theme="dark"] .quick-note-preview td {
    border-bottom-color: rgba(255, 255, 255, 0.09);
}

html[data-theme="dark"] .notes-toggle.icon-only {
    border-color: transparent;
    background: transparent;
    color: var(--muted);
    box-shadow: none;
}

.notes-toggle.icon-only:hover,
html[data-theme="dark"] .notes-toggle.icon-only:hover {
    background: transparent;
    color: var(--ink-soft);
}

@media (max-width: 760px) {
    .notes-panel {
        position: static;
        z-index: auto;
        width: auto;
        margin: 0 10px 12px;
        padding: 0;
    }

    .notes-card {
        max-height: none;
        overflow: visible;
        padding: 14px;
    }

    .notes-markdown-help div {
        right: 0;
        width: min(320px, calc(100vw - 42px));
    }
}

@media (max-width: 760px) {
    .school-schedule-form {
        max-width: 100%;
        overflow-x: auto;
        overflow-y: visible;
        overscroll-behavior-x: contain;
        -webkit-overflow-scrolling: touch;
    }

    .school-schedule-form .school-schedule-table {
        width: max-content;
        min-width: 620px;
    }
}

@media (min-width: 1100px) {
    .top-dashboard .daybar {
        gap: 4px;
        padding: 8px;
    }

    .top-dashboard .date-display-text {
        padding-inline: 4px;
    }

    .top-dashboard .today-compact {
        min-height: 32px;
        padding-inline: 12px;
    }

    .top-dashboard .daybar .icon-button {
        width: 30px;
        min-width: 30px;
        height: 30px;
        min-height: 30px;
    }
}

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

@media (max-width: 760px) {
    .top-dashboard {
        width: auto;
        max-width: none;
        margin: 0 10px 10px;
        border: 1px solid rgba(255, 255, 255, 0.46);
        border-radius: 22px;
        padding: 8px;
        background:
            linear-gradient(145deg, rgba(255, 255, 255, 0.32), rgba(255, 255, 255, 0.12)),
            rgba(255, 255, 255, 0.2);
        box-shadow:
            0 18px 48px rgba(25, 34, 43, 0.045),
            inset 0 1px 0 rgba(255, 255, 255, 0.56);
        overflow: hidden;
    }

    .top-dashboard > .topbar {
        width: auto;
        max-width: none;
        margin: 0 0 6px;
        border-color: rgba(255, 255, 255, 0.58);
        background:
            linear-gradient(145deg, rgba(255, 255, 255, 0.62), rgba(255, 255, 255, 0.3)),
            rgba(255, 255, 255, 0.34);
        box-shadow:
            0 18px 48px rgba(25, 34, 43, 0.045),
            inset 0 1px 0 rgba(255, 255, 255, 0.56);
    }

    .top-dashboard > .global-deck {
        margin: 0;
        padding: 0;
        border: 0;
        background: transparent;
        box-shadow: none;
    }

    .top-dashboard .global-module-strip {
        width: 100%;
        gap: 0;
        overflow-y: hidden;
    }

    .top-dashboard .global-card {
        flex: 0 0 100%;
        max-width: 100%;
        overflow: hidden;
    }

    .top-dashboard .global-card {
        background:
            linear-gradient(145deg, rgba(255, 255, 255, 0.58), rgba(255, 255, 255, 0.28)),
            rgba(255, 255, 255, 0.38);
    }

    html[data-theme="dark"] .top-dashboard > .topbar {
        border-color: rgba(255, 255, 255, 0.08);
        background:
            linear-gradient(145deg, rgba(32, 41, 50, 0.96), rgba(18, 24, 31, 0.88)),
            rgba(20, 26, 33, 0.92);
        box-shadow:
            0 18px 54px rgba(0, 0, 0, 0.28),
            inset 0 1px 0 rgba(255, 255, 255, 0.08);
    }

    html[data-theme="dark"] .top-dashboard {
        border-color: rgba(255, 255, 255, 0.08);
        background:
            linear-gradient(145deg, rgba(32, 41, 50, 0.96), rgba(18, 24, 31, 0.88)),
            rgba(20, 26, 33, 0.92);
        box-shadow:
            0 18px 54px rgba(0, 0, 0, 0.28),
            inset 0 1px 0 rgba(255, 255, 255, 0.08);
    }

    html[data-theme="dark"] .top-dashboard .global-card {
        border-color: rgba(255, 255, 255, 0.08);
        background:
            linear-gradient(145deg, rgba(23, 30, 37, 0.94), rgba(17, 23, 30, 0.86)),
            rgba(18, 24, 31, 0.88);
    }

    .school-schedule-form[data-floating="true"] {
        max-width: calc(100vw - 28px) !important;
        overflow-x: auto;
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
    }

    .school-schedule-form[data-floating="true"] .school-schedule-table {
        width: max-content;
        min-width: 620px;
    }

    .member-edit-row {
        grid-template-columns: minmax(0, 1fr) 44px;
        align-items: stretch;
    }

    .member-edit-row input[name="name"] {
        grid-column: 1 / -1;
        width: 100%;
        min-width: 0;
    }

    .member-edit-row input[name="age"] {
        grid-column: 1;
    }

    .member-edit-row input[type="color"] {
        grid-column: 2;
        width: 44px;
        min-width: 44px;
    }

    .member-edit-row button {
        grid-column: 1 / -1;
    }

    .board,
    .app-shell.is-swipe-layout .board {
        width: auto;
        max-width: none;
        margin-right: 10px;
        margin-left: 10px;
        padding-right: 0;
        padding-left: 0;
        overflow-x: auto;
        overflow-y: hidden;
        overflow-y: clip;
        scroll-snap-type: x proximity;
        scroll-padding-inline: 0;
        overscroll-behavior-x: contain;
        overscroll-behavior-y: auto;
        touch-action: pan-x pan-y;
        -webkit-overflow-scrolling: touch;
    }

    .member-column,
    .app-shell.is-swipe-layout .member-column {
        flex: 0 0 100%;
        min-width: 100%;
        max-width: 100%;
        overflow-x: visible;
        overflow-y: visible !important;
        max-height: none;
        scroll-snap-align: start;
    }

    .member-column,
    .person-module,
    .person-modules,
    .task-list,
    .task-item {
        touch-action: pan-x pan-y;
        overscroll-behavior: auto;
    }

    textarea {
        resize: none;
    }
}

/* Skin architecture: final layer. Skins define material, density defines usable spacing. */
:root {
    --base-board-gap: 14px;
    --base-column-pad: 20px;
    --base-module-gap: 12px;
    --base-module-pad: 14px;
    --base-card-radius: 18px;
    --base-module-radius: 16px;
    --base-control-size: 34px;
    --ui-gap-extra: 0px;
    --ui-pad-extra: 0px;
    --ui-radius-extra: 0px;
    --ui-control-extra: 0px;
    --ui-line-extra: 0px;
    --layout-board-gap: calc(var(--base-board-gap) + var(--ui-gap-extra));
    --layout-column-pad: calc(var(--base-column-pad) + var(--ui-pad-extra));
    --layout-module-gap: calc(var(--base-module-gap) + var(--ui-gap-extra));
    --layout-module-pad: calc(var(--base-module-pad) + var(--ui-pad-extra));
    --layout-card-radius: max(8px, calc(var(--base-card-radius) + var(--ui-radius-extra)));
    --layout-module-radius: max(7px, calc(var(--base-module-radius) + var(--ui-radius-extra)));
    --layout-control-size: max(26px, calc(var(--base-control-size) + var(--ui-control-extra)));
    --appointment-line-gap: max(0px, var(--ui-line-extra));
    --appointment-line-height: max(15px, calc(18px + var(--ui-line-extra)));
    --appointment-phase-pad-y: max(1px, calc(5px + var(--ui-line-extra)));
    --appointment-phase-min-height: max(32px, calc(54px + var(--ui-line-extra) + var(--ui-line-extra) + var(--ui-line-extra) + var(--ui-line-extra)));
}

html[data-density="comfortable"] {
    --base-board-gap: 18px;
    --base-column-pad: 24px;
    --base-module-gap: 15px;
    --base-module-pad: 17px;
    --base-card-radius: 22px;
    --base-module-radius: 18px;
    --base-control-size: 38px;
}

html[data-density="compact"] {
    --base-board-gap: 10px;
    --base-column-pad: 15px;
    --base-module-gap: 8px;
    --base-module-pad: 10px;
    --base-card-radius: 15px;
    --base-module-radius: 13px;
    --base-control-size: 30px;
}

html[data-density="kiosk"] {
    --base-board-gap: 8px;
    --base-column-pad: 13px;
    --base-module-gap: 7px;
    --base-module-pad: 9px;
    --base-card-radius: 14px;
    --base-module-radius: 12px;
    --base-control-size: 29px;
}

.board,
.app-shell.is-swipe-layout .board {
    gap: var(--layout-board-gap);
}

.member-column {
    padding: var(--layout-column-pad);
    border-radius: var(--layout-card-radius);
}

.person-modules {
    gap: var(--layout-module-gap);
}

.top-dashboard,
.topbar,
.global-card,
.settings-panel,
.share-card,
.notes-card,
.home-guide-card,
.member-column {
    border-radius: var(--layout-card-radius);
}

.person-module,
.phase,
.task-list,
.task-item,
.goal-item,
.reflection-prompt,
.reflection-support-prompt,
.reflection-donation,
.media-overview,
.media-time-field,
.quick-note,
.quick-note-preview,
.quick-note-body,
input,
textarea,
select {
    border-radius: var(--layout-module-radius);
}

.person-module,
.global-card {
    padding: var(--layout-module-pad);
}

.icon-button,
.icon-only,
.secondary-button,
.logout-link,
.settings-inline-form button,
.task-edit-panel button,
.goal-form button,
.media-detail-toggle,
.reflection-item-toggle,
.reflection-write-toggle,
.goal-status-toggle,
.goal-edit-toggle,
.global-info-toggle,
.global-misc-toggle {
    min-width: var(--layout-control-size);
    min-height: var(--layout-control-size);
}

html[data-skin="kids"] body {
    background-color: #f0ff9f;
    background-image:
        radial-gradient(circle at 8% 22%, rgba(255, 255, 255, 0.52) 0 0.7rem, transparent 0.75rem),
        radial-gradient(circle at 90% 18%, rgba(255, 190, 89, 0.3) 0 0.85rem, transparent 0.9rem),
        linear-gradient(45deg, rgba(180, 226, 54, 0.28) 25%, transparent 25% 75%, rgba(180, 226, 54, 0.28) 75%),
        linear-gradient(45deg, rgba(255, 255, 255, 0.38) 25%, transparent 25% 75%, rgba(255, 255, 255, 0.38) 75%),
        linear-gradient(135deg, var(--bg-a), var(--bg-b) 52%, var(--bg-c));
    background-position: 0 0, 0 0, 0 0, 32px 32px, 0 0;
    background-size: auto, auto, 64px 64px, 64px 64px, auto;
}

html[data-skin="kids"] body::before {
    display: block;
    opacity: 0.32;
    background:
        radial-gradient(circle at 7% 31%, #ffffff 0 10px, #4ea7d8 11px 16px, transparent 17px),
        radial-gradient(circle at 92% 30%, #ffffff 0 11px, #e26a6b 12px 18px, transparent 19px),
        radial-gradient(circle at 17% 90%, #ffffff 0 8px, #f0bf38 9px 15px, transparent 16px),
        radial-gradient(circle at 86% 88%, #ffffff 0 8px, #9c78ce 9px 14px, transparent 15px);
}

html[data-skin="kids"] .topbar,
html[data-skin="kids"] .global-card,
html[data-skin="kids"] .member-column,
html[data-skin="kids"] .person-module {
    border-width: 2px;
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 42%, rgba(255, 255, 255, 0.72));
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0.34)),
        color-mix(in srgb, var(--member-color, var(--accent)) 18%, rgba(255, 255, 255, 0.78));
    box-shadow:
        0 18px 0 color-mix(in srgb, var(--member-color, var(--accent)) 16%, transparent),
        0 20px 48px rgba(33, 44, 54, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

html[data-skin="kids"] .global-card {
    border-color: rgba(255, 255, 255, 0.72);
}

html[data-skin="kids"] .task-item,
html[data-skin="kids"] .goal-item,
html[data-skin="kids"] .reflection-prompt,
html[data-skin="kids"] .reflection-support-prompt,
html[data-skin="kids"] .media-overview,
html[data-skin="kids"] .phase {
    border-width: 2px;
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 35%, rgba(255, 255, 255, 0.9));
    background: rgba(255, 255, 255, 0.54);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

html[data-skin="kids"] .module-header h2,
html[data-skin="kids"] .global-card h2,
html[data-skin="kids"] .phase-title h3 {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 48%, var(--ink));
    font-weight: 700;
}

html[data-skin="kids"] .member-title h2 {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 60%, var(--ink));
    font-weight: 620;
}

html[data-skin="metal"] body {
    background-color: #8d9398;
    background-image:
        radial-gradient(circle at 34% 14%, rgba(255, 255, 255, 0.34), transparent 14%),
        radial-gradient(circle at 86% 36%, rgba(255, 255, 255, 0.24), transparent 18%),
        repeating-linear-gradient(105deg, rgba(255, 255, 255, 0.13) 0 1px, rgba(0, 0, 0, 0.08) 1px 3px),
        linear-gradient(135deg, #51585f 0%, #b7bdc0 48%, #676d73 100%);
}

html[data-skin="metal"] body::before {
    display: block;
    opacity: 0.34;
    background:
        radial-gradient(circle at 10% 10%, rgba(255, 255, 255, 0.28) 0 1px, transparent 1px 100%),
        repeating-linear-gradient(0deg, transparent 0 28px, rgba(255, 255, 255, 0.05) 29px 30px),
        repeating-linear-gradient(90deg, transparent 0 28px, rgba(0, 0, 0, 0.04) 29px 30px);
}

html[data-skin="metal"] .topbar,
html[data-skin="metal"] .global-card,
html[data-skin="metal"] .member-column,
html[data-skin="metal"] .person-module,
html[data-skin="metal"] .phase,
html[data-skin="metal"] .task-item,
html[data-skin="metal"] .goal-item,
html[data-skin="metal"] .reflection-prompt,
html[data-skin="metal"] .reflection-support-prompt,
html[data-skin="metal"] .media-overview {
    border-color: rgba(255, 255, 255, 0.38);
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.22), rgba(0, 0, 0, 0.12)),
        repeating-linear-gradient(100deg, rgba(255, 255, 255, 0.09) 0 1px, rgba(0, 0, 0, 0.055) 1px 3px),
        color-mix(in srgb, var(--member-color, #858b90) 6%, rgba(103, 111, 118, 0.86));
    box-shadow:
        0 18px 38px rgba(0, 0, 0, 0.24),
        inset 0 1px 0 rgba(255, 255, 255, 0.34),
        inset 0 -1px 0 rgba(0, 0, 0, 0.24);
}

html[data-skin="metal"] .member-column {
    border-color: color-mix(in srgb, var(--member-color, #aeb4b8) 26%, rgba(255, 255, 255, 0.36));
}

html[data-skin="metal"] input,
html[data-skin="metal"] textarea,
html[data-skin="metal"] select,
html[data-skin="metal"] .media-scale,
html[data-skin="metal"] .family-upgrade-track {
    border-color: rgba(10, 14, 18, 0.45);
    background:
        linear-gradient(180deg, rgba(0, 0, 0, 0.16), rgba(255, 255, 255, 0.1)),
        rgba(255, 255, 255, 0.14);
    box-shadow:
        inset 0 2px 6px rgba(0, 0, 0, 0.22),
        inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

html[data-skin="metal"] .icon-button,
html[data-skin="metal"] .icon-only,
html[data-skin="metal"] .secondary-button,
html[data-skin="metal"] .logout-link,
html[data-skin="metal"] .family-highlight-counter,
html[data-skin="metal"] .media-summary .media-chip,
html[data-skin="metal"] .media-balance-pill {
    border: 1px solid rgba(255, 255, 255, 0.26);
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.22), rgba(0, 0, 0, 0.18)),
        rgba(118, 126, 132, 0.56);
    box-shadow:
        0 8px 18px rgba(0, 0, 0, 0.16),
        inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

html[data-theme="dark"][data-skin="metal"] body {
    background-color: #3b4045;
    background-image:
        radial-gradient(circle at 34% 14%, rgba(255, 255, 255, 0.18), transparent 14%),
        radial-gradient(circle at 86% 36%, rgba(255, 255, 255, 0.12), transparent 18%),
        repeating-linear-gradient(105deg, rgba(255, 255, 255, 0.08) 0 1px, rgba(0, 0, 0, 0.18) 1px 3px),
        linear-gradient(135deg, #22272c 0%, #555c63 48%, #282d32 100%);
}

html[data-theme="dark"][data-skin="metal"] .topbar,
html[data-theme="dark"][data-skin="metal"] .global-card,
html[data-theme="dark"][data-skin="metal"] .member-column,
html[data-theme="dark"][data-skin="metal"] .person-module,
html[data-theme="dark"][data-skin="metal"] .phase,
html[data-theme="dark"][data-skin="metal"] .task-item,
html[data-theme="dark"][data-skin="metal"] .goal-item,
html[data-theme="dark"][data-skin="metal"] .reflection-prompt,
html[data-theme="dark"][data-skin="metal"] .reflection-support-prompt,
html[data-theme="dark"][data-skin="metal"] .media-overview {
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.1), rgba(0, 0, 0, 0.28)),
        repeating-linear-gradient(100deg, rgba(255, 255, 255, 0.055) 0 1px, rgba(0, 0, 0, 0.12) 1px 3px),
        color-mix(in srgb, var(--member-color, #4d5358) 5%, rgba(40, 45, 50, 0.92));
}

/* Kids skin: layered paper/sticker system. */
html[data-skin="kids"] {
    --skin-ink-outline: rgba(35, 44, 55, 0.78);
    --skin-paper-edge: rgba(255, 255, 255, 0.86);
    --skin-sticker-shadow: 0 9px 0 rgba(55, 76, 88, 0.08), 0 18px 28px rgba(55, 76, 88, 0.16);
}

html[data-skin="kids"] .app-shell {
    isolation: isolate;
}

html[data-skin="kids"] .app-shell::before {
    display: block;
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    content: "";
    background:
        radial-gradient(circle at 5% 25%, #f6fbff 0 18px, #53aedc 19px 28px, #ffffff 29px 36px, transparent 37px),
        radial-gradient(circle at 94% 23%, #fff7e4 0 16px, #ee786e 17px 28px, #ffffff 29px 36px, transparent 37px),
        radial-gradient(circle at 17% 92%, #fff2b7 0 15px, #e5b836 16px 27px, #ffffff 28px 35px, transparent 36px),
        radial-gradient(circle at 86% 89%, #f3eeff 0 14px, #a589db 15px 26px, #ffffff 27px 34px, transparent 35px);
    opacity: 0.8;
    filter: drop-shadow(0 12px 12px rgba(61, 76, 87, 0.16));
}

html[data-skin="kids"] .top-dashboard,
html[data-skin="kids"] .topbar,
html[data-skin="kids"] .global-card {
    border: 2px solid rgba(255, 255, 255, 0.78);
    background:
        linear-gradient(145deg, rgba(255, 255, 238, 0.82), rgba(255, 255, 255, 0.42)),
        color-mix(in srgb, var(--accent) 7%, rgba(255, 255, 255, 0.74));
    box-shadow: var(--skin-sticker-shadow), inset 0 2px 0 rgba(255, 255, 255, 0.88);
}

html[data-skin="kids"] .member-column {
    padding-top: calc(var(--layout-column-pad) + 22px);
    border-width: 3px;
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, #ffffff);
    background:
        linear-gradient(155deg, rgba(255, 255, 255, 0.62), rgba(255, 255, 255, 0.22)),
        color-mix(in srgb, var(--member-color, var(--accent)) 34%, rgba(255, 255, 255, 0.72));
    box-shadow:
        0 6px 0 color-mix(in srgb, var(--member-color, var(--accent)) 54%, rgba(41, 56, 66, 0.14)),
        0 24px 34px rgba(41, 56, 66, 0.16),
        inset 0 2px 0 rgba(255, 255, 255, 0.72);
    transform: rotate(var(--skin-tilt, 0deg));
}

html[data-skin="kids"] .member-column:nth-child(5n+1) {
    --skin-tilt: -0.35deg;
}

html[data-skin="kids"] .member-column:nth-child(5n+2) {
    --skin-tilt: 0.28deg;
}

html[data-skin="kids"] .member-column:nth-child(5n+3) {
    --skin-tilt: -0.18deg;
}

html[data-skin="kids"] .member-column:nth-child(5n+4) {
    --skin-tilt: 0.22deg;
}

html[data-skin="kids"] .member-column:nth-child(5n) {
    --skin-tilt: -0.24deg;
}

html[data-skin="kids"] .member-column::before {
    position: absolute;
    top: -18px;
    left: 50%;
    z-index: 2;
    display: grid;
    width: 58px;
    height: 58px;
    place-items: center;
    border: 5px solid #fff;
    border-radius: 999px;
    color: color-mix(in srgb, var(--member-color, var(--accent)) 72%, #20303a);
    content: var(--skin-badge, "★");
    background:
        radial-gradient(circle at 36% 30%, rgba(255, 255, 255, 0.9), transparent 0 22%),
        color-mix(in srgb, var(--member-color, var(--accent)) 26%, #fffaf1);
    box-shadow: 0 8px 0 rgba(35, 45, 55, 0.08), 0 14px 20px rgba(35, 45, 55, 0.2);
    font-size: 1.7rem;
    font-weight: 800;
    line-height: 1;
    transform: translateX(-50%) rotate(-4deg);
}

html[data-skin="kids"] .member-column:nth-child(5n+1)::before {
    --skin-badge: "✦";
}

html[data-skin="kids"] .member-column:nth-child(5n+2)::before {
    --skin-badge: "⌂";
}

html[data-skin="kids"] .member-column:nth-child(5n+3)::before {
    --skin-badge: "●";
}

html[data-skin="kids"] .member-column:nth-child(5n+4)::before {
    --skin-badge: "♡";
}

html[data-skin="kids"] .member-column:nth-child(5n)::before {
    --skin-badge: "✧";
}

html[data-skin="kids"] .member-title h2 {
    color: #17202a;
    font-size: 1.16rem;
    font-weight: 800;
    text-shadow:
        0 2px 0 rgba(255, 255, 255, 0.86),
        1px 0 0 rgba(255, 255, 255, 0.78),
        -1px 0 0 rgba(255, 255, 255, 0.78);
}

html[data-skin="kids"] .appointments-module,
html[data-skin="kids"] .goals-module,
html[data-skin="kids"] .reflection-module,
html[data-skin="kids"] .family-question-module,
html[data-skin="kids"] .reflection-donation-module,
html[data-skin="kids"] .media-module {
    border-width: 2px;
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, #ffffff);
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.66), rgba(255, 255, 255, 0.34)),
        color-mix(in srgb, var(--member-color, var(--accent)) 11%, rgba(255, 255, 255, 0.78));
    box-shadow:
        0 5px 0 color-mix(in srgb, var(--member-color, var(--accent)) 32%, rgba(45, 62, 75, 0.08)),
        0 12px 22px rgba(45, 62, 75, 0.1),
        inset 0 2px 0 rgba(255, 255, 255, 0.82);
}

html[data-skin="kids"] .module-header,
html[data-skin="kids"] .goals-header,
html[data-skin="kids"] .appointments-module .module-header {
    border-bottom-color: rgba(255, 255, 255, 0.72);
    background: transparent;
}

html[data-skin="kids"] .appointment-title-toggle,
html[data-skin="kids"] .goal-title-toggle,
html[data-skin="kids"] .module-header h2,
html[data-skin="kids"] .global-card h2,
html[data-skin="kids"] .phase-title h3 {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 62%, #27323b);
    font-weight: 780;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.72);
}

html[data-skin="kids"] .task-item,
html[data-skin="kids"] .goal-item,
html[data-skin="kids"] .reflection-prompt,
html[data-skin="kids"] .reflection-support-prompt,
html[data-skin="kids"] .reflection-check-card,
html[data-skin="kids"] .media-time-field,
html[data-skin="kids"] .media-overview,
html[data-skin="kids"] .phase .school-presence,
html[data-skin="kids"] .family-question-card {
    border: 2px solid color-mix(in srgb, var(--member-color, var(--accent)) 48%, rgba(255, 255, 255, 0.96));
    background: rgba(255, 255, 255, 0.7);
    box-shadow: inset 0 2px 0 rgba(255, 255, 255, 0.9), 0 7px 12px rgba(50, 64, 76, 0.08);
}

html[data-skin="kids"] .media-scale {
    height: 22px;
    border: 2px solid rgba(49, 60, 72, 0.16);
    background:
        repeating-linear-gradient(90deg, rgba(49, 60, 72, 0.24) 0 2px, transparent 2px 20px),
        linear-gradient(90deg, rgba(235, 133, 137, 0.46), rgba(255, 255, 255, 0.72) 50%, rgba(112, 205, 164, 0.58));
}

html[data-skin="kids"] .family-point-links path {
    stroke-width: 3px;
    opacity: 0.86;
    filter:
        drop-shadow(0 2px 0 rgba(255, 255, 255, 0.9))
        drop-shadow(0 6px 5px rgba(38, 55, 68, 0.18));
}

html[data-skin="kids"] .icon-button,
html[data-skin="kids"] .icon-only,
html[data-skin="kids"] .secondary-button,
html[data-skin="kids"] .logout-link,
html[data-skin="kids"] .global-head-toggle,
html[data-skin="kids"] .family-highlight-counter,
html[data-skin="kids"] .media-summary .media-chip,
html[data-skin="kids"] .media-balance-pill {
    border: 2px solid rgba(255, 255, 255, 0.72);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(255, 255, 255, 0.46)),
        color-mix(in srgb, var(--member-color, var(--accent)) 16%, #fff);
    box-shadow: 0 5px 0 rgba(43, 56, 66, 0.07), inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

html[data-skin="kids"] .person-module.earns-family-point,
html[data-skin="kids"] .person-module.is-complete.earns-family-point,
html[data-skin="kids"] .appointments-module.is-empty-complete.earns-family-point {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 82%, #ffffff);
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.74),
        0 0 0 6px color-mix(in srgb, var(--member-color, var(--accent)) 28%, transparent),
        0 10px 18px rgba(45, 62, 75, 0.14),
        inset 0 2px 0 rgba(255, 255, 255, 0.92);
}

/* Metal skin: brushed plates, countersunk controls and stronger material hierarchy. */
html[data-skin="metal"] {
    --metal-line: rgba(255, 255, 255, 0.42);
    --metal-groove: rgba(0, 0, 0, 0.38);
    --metal-soft: rgba(255, 255, 255, 0.14);
}

html[data-skin="metal"] .app-shell {
    isolation: isolate;
}

html[data-skin="metal"] .app-shell::before {
    display: block;
    position: fixed;
    inset: 12px;
    z-index: -1;
    pointer-events: none;
    content: "";
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 18px;
    background:
        radial-gradient(circle at 18px 18px, rgba(0, 0, 0, 0.46) 0 5px, rgba(255, 255, 255, 0.22) 6px 7px, transparent 8px),
        radial-gradient(circle at calc(100% - 18px) 18px, rgba(0, 0, 0, 0.46) 0 5px, rgba(255, 255, 255, 0.22) 6px 7px, transparent 8px),
        radial-gradient(circle at 18px calc(100% - 18px), rgba(0, 0, 0, 0.46) 0 5px, rgba(255, 255, 255, 0.22) 6px 7px, transparent 8px),
        radial-gradient(circle at calc(100% - 18px) calc(100% - 18px), rgba(0, 0, 0, 0.46) 0 5px, rgba(255, 255, 255, 0.22) 6px 7px, transparent 8px);
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.24);
}

html[data-skin="metal"] .top-dashboard,
html[data-skin="metal"] .topbar,
html[data-skin="metal"] .global-card,
html[data-skin="metal"] .member-column {
    border: 1px solid rgba(255, 255, 255, 0.34);
    background:
        radial-gradient(circle at 72% 20%, rgba(255, 255, 255, 0.26), transparent 0 20%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.2), rgba(0, 0, 0, 0.16)),
        repeating-linear-gradient(100deg, rgba(255, 255, 255, 0.08) 0 1px, rgba(0, 0, 0, 0.045) 1px 3px),
        color-mix(in srgb, var(--member-color, #8a9095) 5%, rgba(111, 118, 124, 0.84));
    box-shadow:
        0 18px 34px rgba(0, 0, 0, 0.22),
        inset 0 1px 0 rgba(255, 255, 255, 0.42),
        inset 0 -1px 0 rgba(0, 0, 0, 0.32);
}

html[data-skin="metal"] .member-column {
    border-color: color-mix(in srgb, var(--member-color, #b8bec2) 30%, rgba(255, 255, 255, 0.34));
}

html[data-skin="metal"] .person-module,
html[data-skin="metal"] .task-item,
html[data-skin="metal"] .goal-item,
html[data-skin="metal"] .reflection-prompt,
html[data-skin="metal"] .reflection-support-prompt,
html[data-skin="metal"] .media-overview,
html[data-skin="metal"] .media-time-field,
html[data-skin="metal"] .phase,
html[data-skin="metal"] .family-question-card {
    border: 1px solid rgba(12, 15, 18, 0.58);
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.14), rgba(0, 0, 0, 0.2)),
        repeating-linear-gradient(100deg, rgba(255, 255, 255, 0.065) 0 1px, rgba(0, 0, 0, 0.065) 1px 3px),
        rgba(82, 88, 94, 0.76);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.28),
        inset 0 -1px 0 rgba(0, 0, 0, 0.28),
        0 9px 16px rgba(0, 0, 0, 0.18);
}

html[data-skin="metal"] .person-module.earns-family-point,
html[data-skin="metal"] .person-module.is-complete.earns-family-point,
html[data-skin="metal"] .appointments-module.is-empty-complete.earns-family-point {
    border-color: color-mix(in srgb, var(--member-color, #d7dde1) 64%, rgba(255, 255, 255, 0.3));
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.24),
        0 0 0 4px color-mix(in srgb, var(--member-color, #d7dde1) 18%, transparent),
        inset 0 1px 0 rgba(255, 255, 255, 0.34),
        0 10px 22px rgba(0, 0, 0, 0.24);
}

html[data-skin="metal"] .module-header,
html[data-skin="metal"] .goals-header,
html[data-skin="metal"] .appointments-module .module-header {
    border-bottom-color: rgba(255, 255, 255, 0.15);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(0, 0, 0, 0.05));
}

html[data-skin="metal"] .appointment-title-toggle,
html[data-skin="metal"] .goal-title-toggle,
html[data-skin="metal"] .module-header h2,
html[data-skin="metal"] .global-card h2,
html[data-skin="metal"] .phase-title h3,
html[data-skin="metal"] .member-title h2 {
    color: color-mix(in srgb, var(--member-color, var(--ink)) 28%, var(--ink));
    font-weight: 700;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.14);
}

html[data-skin="metal"] .family-upgrade-track,
html[data-skin="metal"] .media-scale {
    border: 1px solid rgba(0, 0, 0, 0.54);
    background:
        linear-gradient(180deg, rgba(0, 0, 0, 0.44), rgba(255, 255, 255, 0.06)),
        linear-gradient(90deg, rgba(143, 70, 85, 0.5), rgba(0, 0, 0, 0.26) 50%, rgba(100, 171, 144, 0.52));
    box-shadow:
        inset 0 2px 7px rgba(0, 0, 0, 0.38),
        inset 0 -1px 0 rgba(255, 255, 255, 0.2);
}

html[data-skin="metal"] .family-point-links path {
    stroke-width: 2px;
    opacity: 0.78;
    filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.26)) drop-shadow(0 4px 4px rgba(0, 0, 0, 0.2));
}

html[data-skin="metal"] input,
html[data-skin="metal"] textarea,
html[data-skin="metal"] select {
    border: 1px solid rgba(12, 15, 18, 0.52);
    background:
        linear-gradient(180deg, rgba(0, 0, 0, 0.16), rgba(255, 255, 255, 0.12)),
        rgba(255, 255, 255, 0.12);
    box-shadow:
        inset 0 2px 6px rgba(0, 0, 0, 0.24),
        inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

html[data-skin="metal"] .task-state,
html[data-skin="metal"] .goal-status-toggle,
html[data-skin="metal"] .reflection-item-toggle,
html[data-skin="metal"] .media-balance-pill {
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.34),
        0 4px 8px rgba(0, 0, 0, 0.2);
}

/* Zen garden skin: quiet paper, sand lines and stone-like depth. */
html[data-skin="zen"] {
    --zen-ink: rgba(54, 58, 54, 0.82);
    --zen-muted: rgba(102, 111, 106, 0.62);
    --zen-line: rgba(93, 112, 109, 0.18);
    --zen-paper: rgba(255, 253, 247, 0.78);
    --zen-paper-strong: rgba(255, 254, 249, 0.9);
}

html[data-skin="zen"] body {
    background-color: #f1eee6;
    background-image:
        radial-gradient(ellipse at 70% 18%, rgba(153, 145, 125, 0.18), transparent 0 18%),
        radial-gradient(ellipse at 14% 84%, rgba(107, 122, 111, 0.12), transparent 0 22%),
        repeating-radial-gradient(ellipse at 50% 45%, transparent 0 13px, rgba(107, 122, 126, 0.12) 14px 16px, transparent 17px 30px),
        linear-gradient(135deg, #faf7ee 0%, #eae7df 56%, #f6f3ec 100%);
}

html[data-skin="zen"] body::before {
    display: block;
    inset: -18% -12%;
    opacity: 0.46;
    background:
        repeating-radial-gradient(ellipse at 20% 62%, transparent 0 24px, rgba(72, 91, 94, 0.11) 25px 27px, transparent 28px 46px),
        repeating-radial-gradient(ellipse at 82% 28%, transparent 0 18px, rgba(120, 110, 92, 0.1) 19px 21px, transparent 22px 38px),
        linear-gradient(115deg, transparent 0 42%, rgba(255, 255, 255, 0.4) 43% 46%, transparent 47%);
}

html[data-skin="zen"] body::after {
    display: block;
    inset: auto 7vw 4vh auto;
    width: min(320px, 34vw);
    height: min(170px, 22vh);
    border: 0;
    border-radius: 50%;
    background:
        radial-gradient(ellipse at 42% 46%, rgba(99, 94, 83, 0.2), transparent 0 34%),
        radial-gradient(ellipse at 58% 52%, rgba(255, 255, 255, 0.42), transparent 0 36%),
        radial-gradient(ellipse at 50% 52%, rgba(105, 103, 96, 0.18), transparent 0 62%);
    box-shadow: none;
    opacity: 0.42;
}

html[data-skin="zen"] .top-dashboard,
html[data-skin="zen"] .topbar,
html[data-skin="zen"] .global-card,
html[data-skin="zen"] .settings-panel,
html[data-skin="zen"] .share-card,
html[data-skin="zen"] .notes-card,
html[data-skin="zen"] .home-guide-card {
    border-color: rgba(110, 124, 118, 0.18);
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.78), rgba(255, 250, 238, 0.56)),
        rgba(250, 247, 238, 0.7);
    box-shadow:
        0 18px 46px rgba(70, 80, 74, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

html[data-skin="zen"] .member-column {
    border-color: color-mix(in srgb, var(--member-color, #789286) 28%, rgba(111, 123, 116, 0.2));
    background:
        radial-gradient(ellipse at 86% 14%, color-mix(in srgb, var(--member-color, #789286) 14%, transparent), transparent 0 24%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.68), rgba(250, 247, 239, 0.58)),
        color-mix(in srgb, var(--member-color, #789286) 6%, rgba(250, 247, 239, 0.84));
    box-shadow:
        0 22px 58px rgba(66, 75, 70, 0.11),
        inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

html[data-skin="zen"] .member-column::before {
    position: absolute;
    top: 18px;
    right: 22px;
    width: 46px;
    height: 26px;
    pointer-events: none;
    content: "";
    border-radius: 50%;
    background:
        radial-gradient(ellipse at 34% 28%, rgba(255, 255, 255, 0.5), transparent 0 28%),
        linear-gradient(145deg, rgba(113, 110, 99, 0.22), rgba(255, 255, 255, 0.36)),
        color-mix(in srgb, var(--member-color, #789286) 12%, #d7d1c4);
    box-shadow: 0 12px 22px rgba(62, 70, 65, 0.1);
    opacity: 0.5;
}

html[data-skin="zen"] .person-module,
html[data-skin="zen"] .phase,
html[data-skin="zen"] .task-list,
html[data-skin="zen"] .task-item,
html[data-skin="zen"] .goal-item,
html[data-skin="zen"] .reflection-prompt,
html[data-skin="zen"] .reflection-support-prompt,
html[data-skin="zen"] .reflection-check-card,
html[data-skin="zen"] .reflection-donation,
html[data-skin="zen"] .media-overview,
html[data-skin="zen"] .media-time-field,
html[data-skin="zen"] .quick-note,
html[data-skin="zen"] .quick-note-preview,
html[data-skin="zen"] .quick-note-body,
html[data-skin="zen"] .family-question-card,
html[data-skin="zen"] .phase .school-presence {
    border-color: color-mix(in srgb, var(--member-color, #789286) 22%, rgba(100, 111, 105, 0.16));
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.62), rgba(250, 247, 240, 0.68)),
        rgba(255, 252, 246, 0.66);
    box-shadow:
        0 10px 28px rgba(69, 78, 73, 0.06),
        inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

html[data-skin="zen"] .appointment-title-toggle,
html[data-skin="zen"] .goal-title-toggle,
html[data-skin="zen"] .module-header h2,
html[data-skin="zen"] .global-card h2,
html[data-skin="zen"] .phase-title h3,
html[data-skin="zen"] .member-title h2 {
    color: color-mix(in srgb, var(--member-color, #789286) 40%, var(--zen-ink));
    font-weight: 640;
    letter-spacing: 0.02em;
}

html[data-skin="zen"] input,
html[data-skin="zen"] textarea,
html[data-skin="zen"] select {
    border-color: rgba(103, 118, 111, 0.2);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(250, 247, 239, 0.54)),
        rgba(255, 253, 248, 0.68);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

html[data-skin="zen"] .icon-button,
html[data-skin="zen"] .icon-only,
html[data-skin="zen"] .secondary-button,
html[data-skin="zen"] .logout-link,
html[data-skin="zen"] .global-head-toggle,
html[data-skin="zen"] .family-highlight-counter,
html[data-skin="zen"] .media-summary .media-chip,
html[data-skin="zen"] .media-balance-pill,
html[data-skin="zen"] .task-state,
html[data-skin="zen"] .goal-status-toggle,
html[data-skin="zen"] .reflection-item-toggle {
    border-color: rgba(105, 118, 111, 0.2);
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.82), rgba(238, 233, 220, 0.58)),
        color-mix(in srgb, var(--member-color, #789286) 8%, rgba(250, 247, 238, 0.8));
    box-shadow:
        0 8px 18px rgba(68, 77, 72, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

html[data-skin="zen"] .family-upgrade-track,
html[data-skin="zen"] .media-scale {
    border-color: rgba(94, 109, 102, 0.18);
    background:
        linear-gradient(90deg, rgba(178, 126, 125, 0.28), rgba(255, 255, 255, 0.68) 50%, rgba(107, 157, 133, 0.34)),
        rgba(250, 247, 239, 0.76);
    box-shadow: inset 0 2px 8px rgba(83, 96, 90, 0.12);
}

html[data-skin="zen"] .family-point-links path {
    stroke-width: 2.5px;
    opacity: 0.64;
    filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.68));
}

html[data-theme="dark"][data-skin="zen"] body {
    background-color: #252720;
    background-image:
        radial-gradient(ellipse at 70% 18%, rgba(155, 144, 110, 0.12), transparent 0 18%),
        repeating-radial-gradient(ellipse at 50% 45%, transparent 0 13px, rgba(165, 174, 160, 0.07) 14px 16px, transparent 17px 30px),
        linear-gradient(135deg, #181b18 0%, #2c2b25 58%, #1e221f 100%);
}

html[data-theme="dark"][data-skin="zen"] .top-dashboard,
html[data-theme="dark"][data-skin="zen"] .topbar,
html[data-theme="dark"][data-skin="zen"] .global-card,
html[data-theme="dark"][data-skin="zen"] .member-column,
html[data-theme="dark"][data-skin="zen"] .person-module,
html[data-theme="dark"][data-skin="zen"] .phase,
html[data-theme="dark"][data-skin="zen"] .task-list,
html[data-theme="dark"][data-skin="zen"] .task-item,
html[data-theme="dark"][data-skin="zen"] .goal-item,
html[data-theme="dark"][data-skin="zen"] .reflection-prompt,
html[data-theme="dark"][data-skin="zen"] .reflection-support-prompt,
html[data-theme="dark"][data-skin="zen"] .media-overview,
html[data-theme="dark"][data-skin="zen"] .media-time-field,
html[data-theme="dark"][data-skin="zen"] .family-question-card {
    border-color: color-mix(in srgb, var(--member-color, #789286) 26%, rgba(218, 216, 198, 0.16));
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(0, 0, 0, 0.14)),
        color-mix(in srgb, var(--member-color, #789286) 5%, rgba(35, 38, 33, 0.88));
    box-shadow:
        0 18px 44px rgba(0, 0, 0, 0.22),
        inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

/* Frosted glass skin: translucent ice, light refraction and soft pressure. */
html[data-skin="frosted"] {
    --frost-line: rgba(255, 255, 255, 0.68);
    --frost-shadow: rgba(77, 115, 146, 0.16);
    --frost-ink: #24425a;
}

html[data-skin="frosted"] body {
    background-color: #e9f8ff;
    background-image:
        radial-gradient(circle at 18% 20%, rgba(255, 255, 255, 0.9), transparent 0 16%),
        radial-gradient(circle at 80% 22%, rgba(150, 220, 255, 0.34), transparent 0 24%),
        radial-gradient(circle at 56% 90%, rgba(196, 229, 255, 0.52), transparent 0 30%),
        linear-gradient(135deg, #f6fdff 0%, #dff2fb 46%, #edfaff 100%);
}

html[data-skin="frosted"] body::before {
    display: block;
    inset: -6% -8%;
    opacity: 0.62;
    background:
        linear-gradient(105deg, transparent 0 18%, rgba(255, 255, 255, 0.52) 20% 22%, transparent 24% 54%, rgba(255, 255, 255, 0.34) 56% 57%, transparent 59%),
        radial-gradient(ellipse at 38% 16%, rgba(255, 255, 255, 0.78), transparent 0 22%),
        repeating-linear-gradient(92deg, rgba(255, 255, 255, 0.18) 0 1px, transparent 1px 28px);
    filter: blur(0.2px);
}

html[data-skin="frosted"] body::after {
    display: block;
    inset: 9vh 5vw auto;
    height: min(70vh, 760px);
    border-color: rgba(255, 255, 255, 0.42);
    background:
        radial-gradient(ellipse at 16% 24%, rgba(255, 255, 255, 0.42), transparent 0 24%),
        radial-gradient(ellipse at 78% 76%, rgba(118, 190, 229, 0.18), transparent 0 30%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.05));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.62);
    opacity: 0.72;
}

html[data-skin="frosted"] .top-dashboard,
html[data-skin="frosted"] .topbar,
html[data-skin="frosted"] .global-card,
html[data-skin="frosted"] .settings-panel,
html[data-skin="frosted"] .share-card,
html[data-skin="frosted"] .notes-card,
html[data-skin="frosted"] .home-guide-card,
html[data-skin="frosted"] .member-column {
    border-color: rgba(255, 255, 255, 0.62);
    background:
        radial-gradient(ellipse at 18% 12%, rgba(255, 255, 255, 0.62), transparent 0 22%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0.12)),
        color-mix(in srgb, var(--member-color, #9ac7dd) 8%, rgba(220, 242, 253, 0.52));
    -webkit-backdrop-filter: blur(24px) saturate(1.35);
    backdrop-filter: blur(24px) saturate(1.35);
    box-shadow:
        0 24px 70px var(--frost-shadow),
        inset 1px 1px 0 rgba(255, 255, 255, 0.86),
        inset -1px -1px 0 rgba(69, 115, 150, 0.1);
}

html[data-skin="frosted"] .person-module,
html[data-skin="frosted"] .phase,
html[data-skin="frosted"] .task-list,
html[data-skin="frosted"] .task-item,
html[data-skin="frosted"] .goal-item,
html[data-skin="frosted"] .reflection-prompt,
html[data-skin="frosted"] .reflection-support-prompt,
html[data-skin="frosted"] .reflection-check-card,
html[data-skin="frosted"] .reflection-donation,
html[data-skin="frosted"] .media-overview,
html[data-skin="frosted"] .media-time-field,
html[data-skin="frosted"] .quick-note,
html[data-skin="frosted"] .quick-note-preview,
html[data-skin="frosted"] .quick-note-body,
html[data-skin="frosted"] .family-question-card,
html[data-skin="frosted"] .phase .school-presence {
    border-color: color-mix(in srgb, var(--member-color, #9ac7dd) 24%, rgba(255, 255, 255, 0.72));
    background:
        radial-gradient(ellipse at 20% 10%, rgba(255, 255, 255, 0.64), transparent 0 28%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.34), rgba(239, 250, 255, 0.13)),
        color-mix(in srgb, var(--member-color, #9ac7dd) 7%, rgba(236, 249, 255, 0.36));
    -webkit-backdrop-filter: blur(18px) saturate(1.28);
    backdrop-filter: blur(18px) saturate(1.28);
    box-shadow:
        0 14px 34px rgba(83, 124, 156, 0.1),
        inset 1px 1px 0 rgba(255, 255, 255, 0.78),
        inset -1px -1px 0 rgba(82, 128, 164, 0.1);
}

html[data-skin="frosted"] .appointment-title-toggle,
html[data-skin="frosted"] .goal-title-toggle,
html[data-skin="frosted"] .module-header h2,
html[data-skin="frosted"] .global-card h2,
html[data-skin="frosted"] .phase-title h3,
html[data-skin="frosted"] .member-title h2 {
    color: color-mix(in srgb, var(--member-color, #7fb5d3) 38%, #24425a);
    font-weight: 650;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.6);
}

html[data-skin="frosted"] input,
html[data-skin="frosted"] textarea,
html[data-skin="frosted"] select {
    border-color: rgba(255, 255, 255, 0.68);
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.58), rgba(235, 249, 255, 0.22)),
        rgba(255, 255, 255, 0.34);
    -webkit-backdrop-filter: blur(14px) saturate(1.25);
    backdrop-filter: blur(14px) saturate(1.25);
    box-shadow:
        inset 1px 1px 0 rgba(255, 255, 255, 0.82),
        inset -1px -1px 0 rgba(82, 130, 164, 0.09);
}

html[data-skin="frosted"] .icon-button,
html[data-skin="frosted"] .icon-only,
html[data-skin="frosted"] .secondary-button,
html[data-skin="frosted"] .logout-link,
html[data-skin="frosted"] .global-head-toggle,
html[data-skin="frosted"] .family-highlight-counter,
html[data-skin="frosted"] .media-summary .media-chip,
html[data-skin="frosted"] .media-balance-pill,
html[data-skin="frosted"] .task-state,
html[data-skin="frosted"] .goal-status-toggle,
html[data-skin="frosted"] .reflection-item-toggle {
    border-color: rgba(255, 255, 255, 0.72);
    background:
        radial-gradient(ellipse at 28% 18%, rgba(255, 255, 255, 0.8), transparent 0 34%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.5), rgba(219, 241, 252, 0.18)),
        color-mix(in srgb, var(--member-color, #9ac7dd) 8%, rgba(255, 255, 255, 0.3));
    -webkit-backdrop-filter: blur(16px) saturate(1.28);
    backdrop-filter: blur(16px) saturate(1.28);
    box-shadow:
        0 10px 24px rgba(76, 121, 157, 0.12),
        inset 1px 1px 0 rgba(255, 255, 255, 0.86),
        inset -1px -1px 0 rgba(77, 124, 158, 0.1);
}

html[data-skin="frosted"] .family-upgrade-track,
html[data-skin="frosted"] .media-scale {
    border-color: rgba(255, 255, 255, 0.62);
    background:
        linear-gradient(90deg, rgba(211, 127, 148, 0.24), rgba(255, 255, 255, 0.68) 50%, rgba(97, 188, 159, 0.34)),
        rgba(227, 245, 253, 0.42);
    -webkit-backdrop-filter: blur(14px) saturate(1.3);
    backdrop-filter: blur(14px) saturate(1.3);
    box-shadow:
        inset 0 3px 10px rgba(71, 118, 150, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

html[data-skin="frosted"] .media-summary .media-chip,
html[data-skin="frosted"] .family-highlight-counter {
    color: rgba(41, 70, 94, 0.74);
}

html[data-skin="frosted"] .person-module.earns-family-point,
html[data-skin="frosted"] .person-module.is-complete.earns-family-point,
html[data-skin="frosted"] .appointments-module.is-empty-complete.earns-family-point {
    border-color: color-mix(in srgb, var(--member-color, #9ac7dd) 56%, rgba(255, 255, 255, 0.9));
    box-shadow:
        0 0 0 2px rgba(255, 255, 255, 0.54),
        0 20px 48px rgba(76, 121, 157, 0.14),
        inset 1px 1px 0 rgba(255, 255, 255, 0.86);
}

html[data-skin="frosted"] .family-point-links path {
    stroke-width: 2.5px;
    opacity: 0.62;
    filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.72)) drop-shadow(0 7px 8px rgba(70, 119, 154, 0.16));
}

html[data-theme="dark"][data-skin="frosted"] body {
    background-color: #101d27;
    background-image:
        radial-gradient(circle at 18% 20%, rgba(255, 255, 255, 0.14), transparent 0 16%),
        radial-gradient(circle at 80% 22%, rgba(110, 190, 232, 0.2), transparent 0 24%),
        linear-gradient(135deg, #08121a 0%, #142533 46%, #0d1822 100%);
}

html[data-theme="dark"][data-skin="frosted"] .top-dashboard,
html[data-theme="dark"][data-skin="frosted"] .topbar,
html[data-theme="dark"][data-skin="frosted"] .global-card,
html[data-theme="dark"][data-skin="frosted"] .member-column,
html[data-theme="dark"][data-skin="frosted"] .person-module,
html[data-theme="dark"][data-skin="frosted"] .phase,
html[data-theme="dark"][data-skin="frosted"] .task-list,
html[data-theme="dark"][data-skin="frosted"] .task-item,
html[data-theme="dark"][data-skin="frosted"] .goal-item,
html[data-theme="dark"][data-skin="frosted"] .reflection-prompt,
html[data-theme="dark"][data-skin="frosted"] .reflection-support-prompt,
html[data-theme="dark"][data-skin="frosted"] .media-overview,
html[data-theme="dark"][data-skin="frosted"] .media-time-field,
html[data-theme="dark"][data-skin="frosted"] .family-question-card {
    border-color: color-mix(in srgb, var(--member-color, #78b7d8) 24%, rgba(255, 255, 255, 0.2));
    background:
        radial-gradient(ellipse at 18% 10%, rgba(255, 255, 255, 0.14), transparent 0 26%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.09), rgba(0, 0, 0, 0.2)),
        color-mix(in srgb, var(--member-color, #78b7d8) 6%, rgba(16, 29, 40, 0.74));
    box-shadow:
        0 22px 56px rgba(0, 0, 0, 0.24),
        inset 1px 1px 0 rgba(255, 255, 255, 0.14),
        inset -1px -1px 0 rgba(7, 16, 24, 0.22);
}

html[data-theme="dark"][data-skin="frosted"] .appointment-title-toggle,
html[data-theme="dark"][data-skin="frosted"] .goal-title-toggle,
html[data-theme="dark"][data-skin="frosted"] .module-header h2,
html[data-theme="dark"][data-skin="frosted"] .global-card h2,
html[data-theme="dark"][data-skin="frosted"] .phase-title h3,
html[data-theme="dark"][data-skin="frosted"] .member-title h2 {
    color: color-mix(in srgb, var(--member-color, #78b7d8) 42%, #d7ecf7);
    text-shadow: none;
}

/* Contrast skin: readable first, with stronger separation and clearer personal colors. */
html[data-skin="contrast"] {
    --bg-a: #f7f9fc;
    --bg-b: #e9eef5;
    --bg-c: #ffffff;
    --glass: #ffffff;
    --glass-strong: #ffffff;
    --glass-soft: #f7f9fc;
    --stroke: rgba(9, 20, 33, 0.34);
    --stroke-muted: rgba(9, 20, 33, 0.24);
    --ink: #06111f;
    --ink-soft: #17283a;
    --muted: #4e6074;
    --accent: #005fcc;
    --accent-warm: #a94f00;
    --danger: #94132d;
    --focus: rgba(0, 95, 204, 0.4);
    --shadow: 0 18px 44px rgba(9, 20, 33, 0.16);
    --shadow-soft: 0 10px 24px rgba(9, 20, 33, 0.12);
}

html[data-skin="contrast"] body {
    background-color: #f4f7fb;
    background-image:
        linear-gradient(180deg, rgba(255, 255, 255, 0.76), rgba(255, 255, 255, 0)),
        repeating-linear-gradient(90deg, rgba(8, 22, 38, 0.035) 0 1px, transparent 1px 28px),
        repeating-linear-gradient(0deg, rgba(8, 22, 38, 0.03) 0 1px, transparent 1px 28px),
        linear-gradient(135deg, #ffffff 0%, #eef3f8 48%, #ffffff 100%);
    color: var(--ink);
}

html[data-skin="contrast"] body::before,
html[data-skin="contrast"] body::after {
    display: none;
}

html[data-skin="contrast"] .top-dashboard,
html[data-skin="contrast"] .topbar,
html[data-skin="contrast"] .global-card,
html[data-skin="contrast"] .settings-panel,
html[data-skin="contrast"] .share-card,
html[data-skin="contrast"] .notes-card,
html[data-skin="contrast"] .home-guide-card {
    border: 2px solid rgba(9, 20, 33, 0.2);
    background: #ffffff;
    box-shadow:
        0 18px 42px rgba(9, 20, 33, 0.15),
        inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

html[data-skin="contrast"] .member-column {
    border: 2px solid color-mix(in srgb, var(--member-color, var(--accent)) 42%, rgba(9, 20, 33, 0.28));
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.9)),
        color-mix(in srgb, var(--member-color, var(--accent)) 8%, #ffffff);
    box-shadow:
        0 22px 52px rgba(9, 20, 33, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

html[data-skin="contrast"] .member-title h2,
html[data-skin="contrast"] .member-reminders,
html[data-skin="contrast"] .member-reminders strong,
html[data-skin="contrast"] .member-reminders span {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 48%, #06111f);
}

html[data-skin="contrast"] .person-module,
html[data-skin="contrast"] .phase,
html[data-skin="contrast"] .task-list,
html[data-skin="contrast"] .task-item,
html[data-skin="contrast"] .goal-item,
html[data-skin="contrast"] .reflection-prompt,
html[data-skin="contrast"] .reflection-support-prompt,
html[data-skin="contrast"] .reflection-check-card,
html[data-skin="contrast"] .reflection-donation,
html[data-skin="contrast"] .media-overview,
html[data-skin="contrast"] .media-time-field,
html[data-skin="contrast"] .quick-note,
html[data-skin="contrast"] .quick-note-preview,
html[data-skin="contrast"] .quick-note-body,
html[data-skin="contrast"] .family-question-card,
html[data-skin="contrast"] .phase .school-presence {
    border: 2px solid color-mix(in srgb, var(--member-color, var(--accent)) 46%, rgba(9, 20, 33, 0.24));
    background: #ffffff;
    color: #06111f;
    box-shadow:
        0 9px 22px rgba(9, 20, 33, 0.09),
        inset 0 1px 0 rgba(255, 255, 255, 0.96);
}

html[data-skin="contrast"] .task-item,
html[data-skin="contrast"] .goal-item,
html[data-skin="contrast"] .reflection-prompt,
html[data-skin="contrast"] .reflection-support-prompt,
html[data-skin="contrast"] .media-time-field {
    border-width: 1.5px;
}

html[data-skin="contrast"] .appointment-title-toggle,
html[data-skin="contrast"] .goal-title-toggle,
html[data-skin="contrast"] .module-header h2,
html[data-skin="contrast"] .global-card h2,
html[data-skin="contrast"] .phase-title h3 {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 46%, #06111f);
    font-weight: 780;
    letter-spacing: 0.04em;
}

html[data-skin="contrast"] .task-text,
html[data-skin="contrast"] .goal-title,
html[data-skin="contrast"] .reflection-question,
html[data-skin="contrast"] .reflection-support-title,
html[data-skin="contrast"] .media-category-title,
html[data-skin="contrast"] .quick-note-preview,
html[data-skin="contrast"] .family-question-card {
    color: #06111f;
}

html[data-skin="contrast"] .muted,
html[data-skin="contrast"] .fine-print,
html[data-skin="contrast"] .goal-week-dots,
html[data-skin="contrast"] .media-category-description,
html[data-skin="contrast"] .reflection-helper-text,
html[data-skin="contrast"] .reflection-prompt-note {
    color: #4e6074;
}

html[data-skin="contrast"] input,
html[data-skin="contrast"] textarea,
html[data-skin="contrast"] select {
    border: 2px solid rgba(9, 20, 33, 0.28);
    background: #ffffff;
    color: #06111f;
    box-shadow: inset 0 1px 2px rgba(9, 20, 33, 0.08);
}

html[data-skin="contrast"] input::placeholder,
html[data-skin="contrast"] textarea::placeholder {
    color: rgba(23, 40, 58, 0.58);
}

html[data-skin="contrast"] button,
html[data-skin="contrast"] .icon-button,
html[data-skin="contrast"] .icon-only,
html[data-skin="contrast"] .secondary-button,
html[data-skin="contrast"] .logout-link,
html[data-skin="contrast"] .global-head-toggle,
html[data-skin="contrast"] .family-highlight-counter,
html[data-skin="contrast"] .media-summary .media-chip,
html[data-skin="contrast"] .media-balance-pill,
html[data-skin="contrast"] .task-state,
html[data-skin="contrast"] .goal-status-toggle,
html[data-skin="contrast"] .reflection-item-toggle,
html[data-skin="contrast"] .reflection-write-toggle {
    border: 1.5px solid rgba(9, 20, 33, 0.24);
    background: #ffffff;
    color: #17283a;
    box-shadow:
        0 4px 12px rgba(9, 20, 33, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

html[data-skin="contrast"] button:hover,
html[data-skin="contrast"] .icon-button:hover,
html[data-skin="contrast"] .icon-only:hover,
html[data-skin="contrast"] .secondary-button:hover,
html[data-skin="contrast"] .global-head-toggle:hover {
    border-color: color-mix(in srgb, var(--accent) 56%, rgba(9, 20, 33, 0.24));
    background: #f6faff;
    color: #06111f;
}

html[data-skin="contrast"] button:focus-visible,
html[data-skin="contrast"] input:focus-visible,
html[data-skin="contrast"] textarea:focus-visible,
html[data-skin="contrast"] select:focus-visible,
html[data-skin="contrast"] [tabindex]:focus-visible {
    outline: 3px solid var(--focus);
    outline-offset: 2px;
}

html[data-skin="contrast"] .task-state.is-done,
html[data-skin="contrast"] .goal-status-toggle.is-done,
html[data-skin="contrast"] .reflection-item-toggle.is-done {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 58%, rgba(9, 20, 33, 0.26));
    background: color-mix(in srgb, var(--member-color, var(--accent)) 20%, #ffffff);
    color: #06111f;
}

html[data-skin="contrast"] .person-module.is-complete,
html[data-skin="contrast"] .appointments-module.is-empty-complete {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 68%, rgba(9, 20, 33, 0.34));
    box-shadow:
        0 0 0 2px color-mix(in srgb, var(--member-color, var(--accent)) 20%, rgba(255, 255, 255, 0)),
        0 12px 26px rgba(9, 20, 33, 0.12);
}

html[data-skin="contrast"] .person-module.earns-family-point,
html[data-skin="contrast"] .person-module.is-complete.earns-family-point,
html[data-skin="contrast"] .appointments-module.is-empty-complete.earns-family-point {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 78%, #06111f);
    box-shadow:
        0 0 0 3px color-mix(in srgb, var(--member-color, var(--accent)) 18%, transparent),
        0 14px 28px rgba(9, 20, 33, 0.16);
}

html[data-skin="contrast"] .family-upgrade-track,
html[data-skin="contrast"] .media-scale {
    border: 2px solid rgba(9, 20, 33, 0.26);
    background:
        linear-gradient(90deg, rgba(170, 54, 72, 0.3), rgba(255, 255, 255, 0.96) 50%, rgba(34, 138, 93, 0.34)),
        #ffffff;
    box-shadow: inset 0 2px 8px rgba(9, 20, 33, 0.12);
}

html[data-skin="contrast"] .family-upgrade-fill {
    background: linear-gradient(90deg, #9bd7bd, #47b482);
}

html[data-skin="contrast"] .media-summary .media-chip.is-over,
html[data-skin="contrast"] .media-balance-pill.is-debt {
    border-color: rgba(148, 19, 45, 0.45);
    color: #7c0f25;
    background: #fff2f4;
}

html[data-skin="contrast"] .media-balance-pill.is-credit {
    border-color: rgba(20, 121, 78, 0.45);
    color: #105f3f;
    background: #effaf5;
}

html[data-skin="contrast"] .family-point-links path {
    stroke-width: 3px;
    opacity: 0.84;
    filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.9));
}

html[data-theme="dark"][data-skin="contrast"] {
    --bg-a: #020611;
    --bg-b: #08111d;
    --bg-c: #020611;
    --glass: #0d1724;
    --glass-strong: #111e2c;
    --glass-soft: #0a1320;
    --stroke: rgba(220, 235, 255, 0.34);
    --stroke-muted: rgba(220, 235, 255, 0.24);
    --ink: #f4f8ff;
    --ink-soft: #d5e3f3;
    --muted: #a9bbce;
    --accent: #70b7ff;
    --accent-warm: #ffb15f;
    --danger: #ff7b91;
    --focus: rgba(112, 183, 255, 0.5);
}

html[data-theme="dark"][data-skin="contrast"] body {
    background-color: #020611;
    background-image:
        repeating-linear-gradient(90deg, rgba(220, 235, 255, 0.045) 0 1px, transparent 1px 28px),
        repeating-linear-gradient(0deg, rgba(220, 235, 255, 0.035) 0 1px, transparent 1px 28px),
        linear-gradient(135deg, #020611 0%, #08111d 52%, #020611 100%);
}

html[data-theme="dark"][data-skin="contrast"] .top-dashboard,
html[data-theme="dark"][data-skin="contrast"] .topbar,
html[data-theme="dark"][data-skin="contrast"] .global-card,
html[data-theme="dark"][data-skin="contrast"] .settings-panel,
html[data-theme="dark"][data-skin="contrast"] .share-card,
html[data-theme="dark"][data-skin="contrast"] .notes-card,
html[data-theme="dark"][data-skin="contrast"] .home-guide-card,
html[data-theme="dark"][data-skin="contrast"] .member-column,
html[data-theme="dark"][data-skin="contrast"] .person-module,
html[data-theme="dark"][data-skin="contrast"] .phase,
html[data-theme="dark"][data-skin="contrast"] .task-list,
html[data-theme="dark"][data-skin="contrast"] .task-item,
html[data-theme="dark"][data-skin="contrast"] .goal-item,
html[data-theme="dark"][data-skin="contrast"] .reflection-prompt,
html[data-theme="dark"][data-skin="contrast"] .reflection-support-prompt,
html[data-theme="dark"][data-skin="contrast"] .media-overview,
html[data-theme="dark"][data-skin="contrast"] .media-time-field,
html[data-theme="dark"][data-skin="contrast"] .family-question-card {
    border-color: color-mix(in srgb, var(--member-color, #70b7ff) 35%, rgba(220, 235, 255, 0.34));
    background: color-mix(in srgb, var(--member-color, #70b7ff) 5%, #0d1724);
    color: #f4f8ff;
    box-shadow:
        0 18px 42px rgba(0, 0, 0, 0.36),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

html[data-theme="dark"][data-skin="contrast"] .appointment-title-toggle,
html[data-theme="dark"][data-skin="contrast"] .goal-title-toggle,
html[data-theme="dark"][data-skin="contrast"] .module-header h2,
html[data-theme="dark"][data-skin="contrast"] .global-card h2,
html[data-theme="dark"][data-skin="contrast"] .phase-title h3,
html[data-theme="dark"][data-skin="contrast"] .member-title h2 {
    color: color-mix(in srgb, var(--member-color, #70b7ff) 46%, #f4f8ff);
}

html[data-theme="dark"][data-skin="contrast"] input,
html[data-theme="dark"][data-skin="contrast"] textarea,
html[data-theme="dark"][data-skin="contrast"] select,
html[data-theme="dark"][data-skin="contrast"] button,
html[data-theme="dark"][data-skin="contrast"] .icon-button,
html[data-theme="dark"][data-skin="contrast"] .icon-only,
html[data-theme="dark"][data-skin="contrast"] .secondary-button,
html[data-theme="dark"][data-skin="contrast"] .logout-link,
html[data-theme="dark"][data-skin="contrast"] .global-head-toggle {
    border-color: rgba(220, 235, 255, 0.3);
    background: #111e2c;
    color: #f4f8ff;
}

/* Church skin: stained glass panels, lead frames and a dark stone wall. */
html[data-skin="church"] {
    --church-lead: #2c2c2c;
    --church-lead-soft: rgba(44, 44, 44, 0.66);
    --church-light: rgba(255, 238, 183, 0.72);
    --church-gold: #d7a94a;
    --church-stone: #211c17;
    color-scheme: light;
}

html[data-theme="dark"][data-skin="church"] {
    --bg-a: #15110e;
    --bg-b: #241e18;
    --bg-c: #0d0a08;
    --glass: rgba(244, 223, 160, 0.5);
    --glass-strong: rgba(255, 235, 181, 0.7);
    --glass-soft: rgba(228, 190, 112, 0.32);
    --stroke: rgba(44, 44, 44, 0.88);
    --stroke-muted: rgba(44, 44, 44, 0.56);
    --ink: #1a1611;
    --ink-soft: #3d3429;
    --muted: #7b6b58;
    --accent: #c49a43;
    --accent-warm: #d08b34;
    --danger: #9b2638;
    --focus: rgba(255, 215, 88, 0.42);
}

html[data-skin="church"] body {
    background-color: #1b1713;
    background-image:
        radial-gradient(circle at 22% 14%, rgba(255, 218, 112, 0.12), transparent 0 20%),
        radial-gradient(circle at 78% 12%, rgba(145, 93, 52, 0.16), transparent 0 24%),
        repeating-linear-gradient(11deg, rgba(255, 255, 255, 0.025) 0 1px, transparent 1px 10px),
        repeating-linear-gradient(92deg, rgba(0, 0, 0, 0.2) 0 2px, transparent 2px 78px),
        linear-gradient(135deg, #2a241e 0%, #15110e 48%, #2c241b 100%);
    color: #1a1611;
    font-family: "Lora", Georgia, "Times New Roman", serif;
}

html[data-skin="church"] body::before {
    display: block;
    inset: -8% -6%;
    opacity: 0.5;
    background:
        radial-gradient(ellipse at 50% 0%, rgba(255, 220, 120, 0.2), transparent 0 38%),
        repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.04) 0 1px, transparent 1px 24px),
        repeating-linear-gradient(90deg, rgba(0, 0, 0, 0.2) 0 1px, transparent 1px 92px);
    mix-blend-mode: overlay;
}

html[data-skin="church"] body::after {
    display: block;
    inset: 7vh 3vw auto;
    height: min(82vh, 920px);
    border: 0;
    border-radius: 44px 44px 16px 16px;
    background:
        linear-gradient(90deg, rgba(0, 0, 0, 0.28) 0 6px, transparent 6px calc(20% - 3px), rgba(0, 0, 0, 0.28) calc(20% - 3px) calc(20% + 3px), transparent calc(20% + 3px) calc(40% - 3px), rgba(0, 0, 0, 0.28) calc(40% - 3px) calc(40% + 3px), transparent calc(40% + 3px) calc(60% - 3px), rgba(0, 0, 0, 0.28) calc(60% - 3px) calc(60% + 3px), transparent calc(60% + 3px) calc(80% - 3px), rgba(0, 0, 0, 0.28) calc(80% - 3px) calc(80% + 3px), transparent calc(80% + 3px) calc(100% - 6px), rgba(0, 0, 0, 0.28) calc(100% - 6px)),
        radial-gradient(ellipse at 50% 0%, rgba(255, 231, 148, 0.16), transparent 0 42%);
    box-shadow: inset 0 0 48px rgba(0, 0, 0, 0.32);
    opacity: 0.9;
}

html[data-skin="church"] body::before,
html[data-skin="church"] body::after {
    z-index: 0;
}

html[data-skin="church"] .app-shell {
    z-index: 2;
    perspective: 1800px;
}

html[data-skin="church"].has-church-scene body {
    background-image:
        radial-gradient(circle at 22% 14%, rgba(255, 218, 112, 0.08), transparent 0 20%),
        linear-gradient(135deg, #241e18 0%, #13100d 50%, #2b231b 100%);
}

html[data-skin="church"].has-church-scene body::before {
    opacity: 0.22;
}

html[data-skin="church"].has-church-scene body::after {
    opacity: 0.26;
}

.church-scene-canvas {
    position: fixed;
    inset: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    opacity: 0;
    transition: opacity 700ms ease;
}

html[data-skin="church"].has-church-scene .church-scene-canvas {
    opacity: 0.92;
}

html[data-skin="church"] .top-dashboard,
html[data-skin="church"] .topbar,
html[data-skin="church"] .global-card,
html[data-skin="church"] .settings-panel,
html[data-skin="church"] .share-card,
html[data-skin="church"] .notes-card,
html[data-skin="church"] .home-guide-card {
    border: 4px solid var(--church-lead);
    border-radius: 30px 30px 8px 8px;
    background:
        radial-gradient(ellipse at 18% 12%, rgba(255, 244, 196, 0.56), transparent 0 28%),
        linear-gradient(135deg, rgba(255, 226, 129, 0.44), rgba(255, 255, 255, 0.44) 44%, rgba(114, 65, 31, 0.26)),
        rgba(255, 237, 184, 0.56);
    -webkit-backdrop-filter: blur(4px) brightness(1.18);
    backdrop-filter: blur(4px) brightness(1.18);
    box-shadow:
        2px 2px 6px rgba(0, 0, 0, 0.68),
        0 12px 22px rgba(0, 0, 0, 0.22),
        inset 1px 1px 2px rgba(255, 255, 255, 0.22),
        inset 0 0 18px rgba(0, 0, 0, 0.2);
}

html[data-skin="church"] .top-dashboard,
html[data-skin="church"] .global-card {
    position: relative;
    overflow: hidden;
}

html[data-skin="church"] .top-dashboard::before,
html[data-skin="church"] .global-card::before {
    position: absolute;
    inset: 0;
    pointer-events: none;
    content: "";
    background:
        repeating-linear-gradient(90deg, rgba(44, 44, 44, 0.2) 0 3px, transparent 3px 72px),
        repeating-linear-gradient(0deg, rgba(44, 44, 44, 0.16) 0 2px, transparent 2px 54px),
        radial-gradient(ellipse at 50% 0%, rgba(255, 255, 255, 0.22), transparent 0 42%);
    mix-blend-mode: multiply;
    opacity: 0.55;
}

html[data-skin="church"] .member-column {
    position: relative;
    overflow: visible;
    padding-top: calc(var(--layout-column-pad) + 30px);
    border: 6px solid var(--church-lead);
    border-radius: 120px 120px 16px 16px;
    background:
        radial-gradient(circle at 50% 26px, rgba(255, 248, 216, 0.82) 0 31px, var(--church-lead) 32px 38px, transparent 39px),
        radial-gradient(ellipse at 50% 0%, color-mix(in srgb, var(--member-color, var(--accent)) 36%, rgba(255, 230, 158, 0.62)), transparent 0 42%),
        linear-gradient(160deg, color-mix(in srgb, var(--member-color, var(--accent)) 42%, rgba(255, 226, 158, 0.56)), rgba(255, 250, 224, 0.52) 48%, color-mix(in srgb, var(--member-color, var(--accent)) 32%, rgba(150, 82, 34, 0.36))),
        rgba(255, 235, 181, 0.58);
    box-shadow:
        5px 8px 16px rgba(0, 0, 0, 0.45),
        0 28px 38px rgba(0, 0, 0, 0.22),
        inset 1px 1px 2px rgba(255, 255, 255, 0.24),
        inset 0 0 26px rgba(0, 0, 0, 0.24);
    transform: translateZ(0) rotateX(0.45deg);
    transform-origin: center top;
}

html[data-skin="church"] .member-column::before {
    position: absolute;
    top: 15px;
    left: 50%;
    z-index: 0;
    width: 58px;
    height: 58px;
    pointer-events: none;
    content: "";
    border: 5px solid var(--church-lead);
    border-radius: 50%;
    background:
        radial-gradient(circle at 34% 30%, rgba(255, 255, 255, 0.86), transparent 0 18%),
        conic-gradient(from 22deg, color-mix(in srgb, var(--member-color, var(--accent)) 72%, #ffe49b), rgba(255, 239, 186, 0.9), color-mix(in srgb, var(--member-color, var(--accent)) 54%, #8b4a25), color-mix(in srgb, var(--member-color, var(--accent)) 72%, #ffe49b));
    box-shadow:
        0 4px 10px rgba(0, 0, 0, 0.4),
        inset 0 0 14px rgba(0, 0, 0, 0.26);
    transform: translateX(-50%);
}

html[data-skin="church"] .member-column::after {
    position: absolute;
    inset: 14px;
    z-index: 0;
    pointer-events: none;
    content: "";
    border: 2px solid rgba(44, 44, 44, 0.38);
    border-radius: 100px 100px 10px 10px;
    background:
        linear-gradient(90deg, transparent 0 18%, rgba(44, 44, 44, 0.2) 18% calc(18% + 3px), transparent calc(18% + 3px) 82%, rgba(44, 44, 44, 0.2) 82% calc(82% + 3px), transparent calc(82% + 3px)),
        linear-gradient(0deg, transparent 0 18%, rgba(44, 44, 44, 0.16) 18% calc(18% + 3px), transparent calc(18% + 3px) 36%, rgba(44, 44, 44, 0.14) 36% calc(36% + 2px), transparent calc(36% + 2px) 64%, rgba(44, 44, 44, 0.14) 64% calc(64% + 2px), transparent calc(64% + 2px));
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.14),
        inset 0 0 28px rgba(0, 0, 0, 0.18);
}

html[data-skin="church"] .member-title,
html[data-skin="church"] .person-module,
html[data-skin="church"] .module-header,
html[data-skin="church"] .member-reminders {
    position: relative;
    z-index: 1;
}

html[data-skin="church"] .member-title h2,
html[data-skin="church"] .appointment-title-toggle,
html[data-skin="church"] .goal-title-toggle,
html[data-skin="church"] .module-header h2,
html[data-skin="church"] .global-card h2,
html[data-skin="church"] .phase-title h3 {
    color: #191510;
    font-family: "Cinzel", "Uncial Antiqua", Georgia, "Times New Roman", serif;
    font-weight: 760;
    letter-spacing: 0.035em;
    text-shadow: 0 1px 2px rgba(255, 255, 255, 0.42);
}

html[data-skin="church"] .member-title h2,
html[data-skin="church"] .member-reminders,
html[data-skin="church"] .member-reminders strong,
html[data-skin="church"] .member-reminders span {
    color: color-mix(in srgb, var(--member-color, var(--accent)) 45%, #15110e);
}

html[data-skin="church"] .person-module,
html[data-skin="church"] .phase,
html[data-skin="church"] .task-list,
html[data-skin="church"] .goal-item,
html[data-skin="church"] .reflection-prompt,
html[data-skin="church"] .reflection-support-prompt,
html[data-skin="church"] .reflection-check-card,
html[data-skin="church"] .reflection-donation,
html[data-skin="church"] .media-overview,
html[data-skin="church"] .media-time-field,
html[data-skin="church"] .quick-note,
html[data-skin="church"] .quick-note-preview,
html[data-skin="church"] .quick-note-body,
html[data-skin="church"] .family-question-card,
html[data-skin="church"] .phase .school-presence {
    border: 3px solid var(--church-lead);
    border-radius: 8px;
    background:
        radial-gradient(ellipse at 18% 10%, rgba(255, 255, 255, 0.56), transparent 0 28%),
        linear-gradient(145deg, color-mix(in srgb, var(--member-color, var(--accent)) 18%, rgba(255, 244, 203, 0.62)), rgba(255, 255, 255, 0.38)),
        rgba(255, 238, 184, 0.54);
    color: #1a1611;
    -webkit-backdrop-filter: blur(4px) brightness(1.12);
    backdrop-filter: blur(4px) brightness(1.12);
    box-shadow:
        2px 2px 6px rgba(0, 0, 0, 0.4),
        inset 1px 1px 2px rgba(255, 255, 255, 0.22),
        inset 0 0 15px rgba(0, 0, 0, 0.24);
}

html[data-skin="church"] .person-module,
html[data-skin="church"] .phase,
html[data-skin="church"] .goal-item,
html[data-skin="church"] .reflection-prompt,
html[data-skin="church"] .reflection-support-prompt,
html[data-skin="church"] .media-overview {
    position: relative;
    overflow: hidden;
}

html[data-skin="church"] .person-module::before,
html[data-skin="church"] .phase::before,
html[data-skin="church"] .goal-item::before,
html[data-skin="church"] .reflection-prompt::before,
html[data-skin="church"] .reflection-support-prompt::before,
html[data-skin="church"] .media-overview::before {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    content: "";
    background:
        radial-gradient(ellipse at 22% 14%, rgba(255, 255, 255, 0.38), transparent 0 30%),
        repeating-linear-gradient(90deg, rgba(44, 44, 44, 0.12) 0 2px, transparent 2px 46px),
        repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.1) 0 1px, transparent 1px 17px);
    opacity: 0.62;
}

html[data-skin="church"] .person-module > *,
html[data-skin="church"] .phase > *,
html[data-skin="church"] .goal-item > *,
html[data-skin="church"] .reflection-prompt > *,
html[data-skin="church"] .reflection-support-prompt > *,
html[data-skin="church"] .media-overview > * {
    position: relative;
    z-index: 1;
}

html[data-skin="church"] .task-item {
    color: #1a1611;
}

html[data-skin="church"] input,
html[data-skin="church"] textarea,
html[data-skin="church"] select {
    border: 2px solid var(--church-lead);
    border-radius: 5px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.64), rgba(243, 226, 172, 0.42)),
        rgba(255, 255, 255, 0.5);
    color: #17120e;
    box-shadow:
        inset 0 1px 4px rgba(0, 0, 0, 0.12),
        inset 1px 1px 0 rgba(255, 255, 255, 0.42);
}

html[data-skin="church"] input::placeholder,
html[data-skin="church"] textarea::placeholder {
    color: rgba(40, 32, 24, 0.56);
}

html[data-skin="church"] button,
html[data-skin="church"] .icon-button,
html[data-skin="church"] .icon-only,
html[data-skin="church"] .secondary-button,
html[data-skin="church"] .logout-link,
html[data-skin="church"] .global-head-toggle,
html[data-skin="church"] .family-highlight-counter,
html[data-skin="church"] .media-summary .media-chip,
html[data-skin="church"] .media-balance-pill,
html[data-skin="church"] .task-state,
html[data-skin="church"] .goal-status-toggle,
html[data-skin="church"] .reflection-item-toggle,
html[data-skin="church"] .reflection-write-toggle {
    border: 3px solid var(--church-lead);
    border-radius: 999px;
    background:
        radial-gradient(circle at 34% 25%, rgba(255, 255, 255, 0.72), transparent 0 34%),
        linear-gradient(145deg, rgba(255, 237, 175, 0.6), color-mix(in srgb, var(--member-color, var(--accent)) 22%, rgba(196, 126, 48, 0.42))),
        rgba(255, 226, 154, 0.58);
    color: #1a1611;
    box-shadow:
        1px 2px 5px rgba(0, 0, 0, 0.36),
        inset 1px 1px 2px rgba(255, 255, 255, 0.22);
}

html[data-skin="church"] button:hover,
html[data-skin="church"] .icon-button:hover,
html[data-skin="church"] .icon-only:hover,
html[data-skin="church"] .secondary-button:hover,
html[data-skin="church"] .global-head-toggle:hover {
    filter: brightness(1.18) drop-shadow(0 0 8px color-mix(in srgb, var(--member-color, var(--accent)) 44%, var(--church-gold)));
}

html[data-skin="church"] button:focus-visible,
html[data-skin="church"] input:focus-visible,
html[data-skin="church"] textarea:focus-visible,
html[data-skin="church"] select:focus-visible,
html[data-skin="church"] [tabindex]:focus-visible {
    outline: 3px solid rgba(255, 215, 88, 0.72);
    outline-offset: 2px;
}

html[data-skin="church"] .family-upgrade-track,
html[data-skin="church"] .media-scale {
    border: 3px solid var(--church-lead);
    border-radius: 6px;
    background:
        repeating-linear-gradient(90deg, rgba(44, 44, 44, 0.42) 0 3px, transparent 3px 30px),
        linear-gradient(90deg, rgba(128, 20, 42, 0.44), rgba(255, 248, 216, 0.78) 50%, rgba(18, 126, 78, 0.54)),
        rgba(0, 0, 0, 0.28);
    box-shadow:
        inset 0 0 12px rgba(0, 0, 0, 0.38),
        1px 2px 5px rgba(0, 0, 0, 0.36);
}

html[data-skin="church"] .family-upgrade-fill {
    background:
        repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.16) 0 8px, transparent 8px 16px),
        linear-gradient(90deg, rgba(60, 174, 116, 0.8), rgba(125, 219, 157, 0.88));
}

html[data-skin="church"] .family-upgrade-today {
    background: linear-gradient(90deg, rgba(255, 214, 89, 0.82), rgba(67, 194, 132, 0.92));
}

html[data-skin="church"] .family-upgrade-milestone {
    background: rgba(44, 44, 44, 0.78);
}

html[data-skin="church"] .family-upgrade-milestone.is-reached {
    background: rgba(42, 139, 84, 0.9);
}

html[data-skin="church"] .goal-week-dots i,
html[data-skin="church"] .media-week-history i {
    border-color: rgba(44, 44, 44, 0.48);
    background: rgba(0, 0, 0, 0.26);
    box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.25);
}

html[data-skin="church"] .person-module.is-complete,
html[data-skin="church"] .appointments-module.is-empty-complete {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 58%, var(--church-lead));
    box-shadow:
        0 0 0 2px rgba(255, 222, 108, 0.22),
        2px 3px 8px rgba(0, 0, 0, 0.4),
        inset 0 0 16px rgba(255, 239, 174, 0.22);
}

html[data-skin="church"] .person-module.earns-family-point,
html[data-skin="church"] .person-module.is-complete.earns-family-point,
html[data-skin="church"] .appointments-module.is-empty-complete.earns-family-point {
    border-width: 4px;
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 64%, var(--church-gold));
    box-shadow:
        0 0 0 2px rgba(44, 44, 44, 0.42),
        0 0 20px rgba(255, 213, 93, 0.2),
        2px 4px 10px rgba(0, 0, 0, 0.44),
        inset 0 0 18px rgba(255, 236, 159, 0.24);
}

html[data-skin="church"] .family-point-links path {
    stroke-width: 4px;
    opacity: 0.86;
    filter: drop-shadow(1px 2px 2px rgba(0, 0, 0, 0.45)) drop-shadow(0 0 5px rgba(255, 218, 112, 0.16));
}

html[data-skin="church"] .media-summary .media-chip.is-over,
html[data-skin="church"] .media-balance-pill.is-debt {
    border-color: #671c2a;
    color: #671c2a;
    background: rgba(255, 202, 211, 0.58);
}

html[data-skin="church"] .media-balance-pill.is-credit {
    border-color: #1f6f4a;
    color: #1f6f4a;
    background: rgba(202, 245, 217, 0.58);
}

html[data-skin="church"] .weather-icon,
html[data-skin="church"] .weather-temp-label,
html[data-skin="church"] .weather-time-label {
    color: #241c15;
    filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.44));
}

html[data-skin="church"] .appointments-module .task-list .task-item {
    background: transparent !important;
    border-color: transparent !important;
    box-shadow: none !important;
}

/* Church skin rework: gothic cathedral, dark stone, saturated glass and forged lead. */
html[data-skin="church"] {
    --church-black: #171410;
    --church-lead: #1a1a1a;
    --church-lead-soft: rgba(26, 26, 26, 0.72);
    --church-parchment: rgba(244, 232, 209, 0.84);
    --church-parchment-strong: rgba(250, 239, 216, 0.92);
    --church-stone-shadow: rgba(0, 0, 0, 0.62);
    --church-emerald: rgba(24, 144, 80, 0.9);
    --church-sapphire: rgba(28, 98, 184, 0.9);
    --church-amber: rgba(227, 126, 34, 0.9);
    --church-ruby: rgba(205, 63, 111, 0.88);
    --church-topaz: rgba(221, 173, 46, 0.9);
    --ink: #171410;
    --ink-soft: #302a23;
    --muted: #6b604f;
}

html[data-skin="church"] body {
    background-color: #130f0b;
    background-image:
        radial-gradient(circle at 50% -8%, rgba(230, 184, 97, 0.16), transparent 0 28%),
        linear-gradient(90deg, rgba(0, 0, 0, 0.34), transparent 16%, transparent 84%, rgba(0, 0, 0, 0.38)),
        repeating-linear-gradient(90deg, rgba(255, 230, 170, 0.045) 0 1px, transparent 1px 72px),
        repeating-linear-gradient(0deg, rgba(0, 0, 0, 0.32) 0 3px, transparent 3px 116px),
        linear-gradient(135deg, #2a2118 0%, #0f0c09 46%, #332719 100%);
    font-family: "Lora", "Segoe UI", Arial, sans-serif;
}

html[data-skin="church"] .app-shell {
    max-width: 1780px;
    margin-inline: auto;
    padding-inline: clamp(14px, 2.1vw, 34px);
}

html[data-skin="church"] body::before {
    opacity: 0.34;
    background:
        radial-gradient(ellipse at 50% 8%, rgba(255, 226, 142, 0.16), transparent 0 34%),
        linear-gradient(90deg, rgba(26, 18, 12, 0.72) 0 3px, transparent 3px 19.6%, rgba(26, 18, 12, 0.78) 19.6% calc(19.6% + 10px), transparent calc(19.6% + 10px) 39.4%, rgba(26, 18, 12, 0.78) 39.4% calc(39.4% + 10px), transparent calc(39.4% + 10px) 59.2%, rgba(26, 18, 12, 0.78) 59.2% calc(59.2% + 10px), transparent calc(59.2% + 10px) 79%, rgba(26, 18, 12, 0.78) 79% calc(79% + 10px), transparent calc(79% + 10px)),
        repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.03) 0 1px, transparent 1px 34px);
}

html[data-skin="church"] body::after {
    inset: 78px 2vw auto;
    height: min(86vh, 930px);
    opacity: 0.78;
    background:
        radial-gradient(ellipse at 10% 58%, rgba(34, 120, 70, 0.22), transparent 0 12%),
        radial-gradient(ellipse at 92% 58%, rgba(212, 160, 42, 0.22), transparent 0 12%),
        linear-gradient(90deg, rgba(0, 0, 0, 0.66) 0 5px, transparent 5px 19.5%, rgba(0, 0, 0, 0.66) 19.5% calc(19.5% + 8px), transparent calc(19.5% + 8px) 39.2%, rgba(0, 0, 0, 0.66) 39.2% calc(39.2% + 8px), transparent calc(39.2% + 8px) 58.9%, rgba(0, 0, 0, 0.66) 58.9% calc(58.9% + 8px), transparent calc(58.9% + 8px) 78.6%, rgba(0, 0, 0, 0.66) 78.6% calc(78.6% + 8px), transparent calc(78.6% + 8px) calc(100% - 5px), rgba(0, 0, 0, 0.66) calc(100% - 5px)),
        linear-gradient(180deg, rgba(20, 13, 8, 0.56), rgba(0, 0, 0, 0.28));
}

html[data-skin="church"].has-church-scene .church-scene-canvas {
    opacity: 1;
    filter: contrast(1.1) saturate(1.15) brightness(0.78);
}

html[data-skin="church"] .top-dashboard,
html[data-skin="church"] .topbar,
html[data-skin="church"] .global-card,
html[data-skin="church"] .settings-panel,
html[data-skin="church"] .share-card,
html[data-skin="church"] .notes-card,
html[data-skin="church"] .home-guide-card {
    border: 5px solid var(--church-lead);
    border-radius: 5px;
    background:
        linear-gradient(90deg, rgba(26, 26, 26, 0.16) 0 3px, transparent 3px 100%),
        repeating-linear-gradient(90deg, rgba(26, 26, 26, 0.22) 0 3px, transparent 3px 56px),
        repeating-linear-gradient(0deg, rgba(26, 26, 26, 0.18) 0 3px, transparent 3px 48px),
        linear-gradient(145deg, rgba(107, 82, 52, 0.86), rgba(201, 179, 127, 0.72) 46%, rgba(57, 41, 26, 0.84));
    box-shadow:
        0 10px 0 rgba(0, 0, 0, 0.32),
        0 22px 34px rgba(0, 0, 0, 0.54),
        inset 0 0 0 2px rgba(255, 238, 183, 0.22),
        inset 0 16px 32px rgba(255, 245, 202, 0.18),
        inset 0 -22px 28px rgba(0, 0, 0, 0.28);
}

html[data-skin="church"] .global-card {
    min-height: 108px;
}

html[data-skin="church"] .weather-card {
    background:
        radial-gradient(circle at 28% 34%, rgba(255, 230, 119, 0.7), transparent 0 18%),
        radial-gradient(ellipse at 68% 34%, rgba(95, 180, 226, 0.74), transparent 0 28%),
        linear-gradient(145deg, rgba(48, 145, 196, 0.72), rgba(250, 225, 128, 0.68) 40%, rgba(84, 168, 113, 0.48)),
        rgba(244, 232, 209, 0.74);
}

html[data-skin="church"] .top-dashboard::before,
html[data-skin="church"] .global-card::before {
    opacity: 0.68;
    background:
        repeating-linear-gradient(90deg, rgba(26, 26, 26, 0.34) 0 4px, transparent 4px 62px),
        repeating-linear-gradient(0deg, rgba(26, 26, 26, 0.26) 0 4px, transparent 4px 46px),
        radial-gradient(ellipse at 50% 0%, rgba(255, 244, 196, 0.22), transparent 0 48%);
}

html[data-skin="church"] .global-card > *,
html[data-skin="church"] .top-dashboard > * {
    position: relative;
    z-index: 1;
}

html[data-skin="church"] .board {
    gap: clamp(18px, 2.1vw, 28px);
    align-items: start;
}

html[data-skin="church"] .member-column {
    --church-column-glass: color-mix(in srgb, var(--member-color, var(--church-emerald)) 74%, rgba(248, 230, 160, 0.26));
    padding: calc(var(--layout-column-pad) + 54px) max(10px, var(--layout-column-pad)) var(--layout-column-pad);
    border: 7px solid var(--church-lead);
    border-radius: 46% 46% 4px 4px / 76px 76px 4px 4px;
    background:
        radial-gradient(circle at 50% 54px, rgba(255, 248, 214, 0.92) 0 34px, var(--church-lead) 35px 44px, transparent 45px),
        radial-gradient(ellipse at 50% 5%, rgba(255, 255, 255, 0.36), transparent 0 23%),
        linear-gradient(90deg, rgba(26, 26, 26, 0.42) 0 8px, transparent 8px calc(100% - 8px), rgba(26, 26, 26, 0.42) calc(100% - 8px)),
        repeating-linear-gradient(90deg, rgba(26, 26, 26, 0.28) 0 4px, transparent 4px 54px),
        repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.1) 0 1px, transparent 1px 32px),
        linear-gradient(180deg, var(--church-column-glass), color-mix(in srgb, var(--member-color, var(--accent)) 52%, rgba(72, 45, 24, 0.66))),
        rgba(50, 31, 19, 0.62);
    clip-path: none;
    box-shadow:
        0 10px 0 rgba(0, 0, 0, 0.38),
        0 30px 48px rgba(0, 0, 0, 0.6),
        inset 0 0 0 4px rgba(255, 244, 195, 0.18),
        inset 0 28px 46px rgba(255, 255, 255, 0.18),
        inset 0 -36px 42px rgba(0, 0, 0, 0.26);
    transform: none;
}

html[data-skin="church"] .member-column:nth-child(5n+1) {
    --church-column-glass: var(--church-emerald);
}

html[data-skin="church"] .member-column:nth-child(5n+2) {
    --church-column-glass: var(--church-sapphire);
}

html[data-skin="church"] .member-column:nth-child(5n+3) {
    --church-column-glass: var(--church-amber);
}

html[data-skin="church"] .member-column:nth-child(5n+4) {
    --church-column-glass: var(--church-ruby);
}

html[data-skin="church"] .member-column:nth-child(5n) {
    --church-column-glass: var(--church-topaz);
}

html[data-skin="church"] .member-column::before {
    top: 20px;
    width: 66px;
    height: 66px;
    border: 7px solid var(--church-lead);
    background:
        radial-gradient(circle at 38% 28%, rgba(255, 255, 255, 0.88), transparent 0 16%),
        radial-gradient(circle at 50% 42%, rgba(244, 232, 209, 0.92) 0 22%, transparent 23%),
        conic-gradient(from 0deg, var(--church-column-glass), rgba(255, 244, 186, 0.92), color-mix(in srgb, var(--member-color, var(--accent)) 72%, #4a2516), var(--church-column-glass));
    box-shadow:
        0 5px 0 rgba(0, 0, 0, 0.34),
        0 12px 18px rgba(0, 0, 0, 0.5),
        inset 0 0 0 3px rgba(255, 241, 184, 0.22),
        inset 0 0 22px rgba(0, 0, 0, 0.4);
}

html[data-skin="church"] .member-column::after {
    inset: 8px;
    border: 5px solid rgba(26, 26, 26, 0.72);
    border-radius: 46% 46% 4px 4px / 70px 70px 4px 4px;
    clip-path: polygon(50% 0, 88% 9%, 100% 18%, 100% 100%, 0 100%, 0 18%, 12% 9%);
    background:
        linear-gradient(90deg, transparent 0 13%, rgba(26, 26, 26, 0.35) 13% calc(13% + 5px), transparent calc(13% + 5px) 87%, rgba(26, 26, 26, 0.35) 87% calc(87% + 5px), transparent calc(87% + 5px)),
        linear-gradient(0deg, transparent 0 22%, rgba(26, 26, 26, 0.24) 22% calc(22% + 4px), transparent calc(22% + 4px) 44%, rgba(26, 26, 26, 0.2) 44% calc(44% + 3px), transparent calc(44% + 3px) 70%, rgba(26, 26, 26, 0.18) 70% calc(70% + 3px), transparent calc(70% + 3px));
}

html[data-skin="church"] .member-title h2 {
    font-family: "Cinzel", "Playfair Display", Georgia, serif;
    font-size: clamp(1.05rem, 1.2vw, 1.45rem);
    font-weight: 900;
    color: #14110d;
    text-shadow:
        0 1px 0 rgba(255, 238, 187, 0.52),
        0 2px 4px rgba(0, 0, 0, 0.34);
}

html[data-skin="church"] .person-module,
html[data-skin="church"] .phase,
html[data-skin="church"] .task-list,
html[data-skin="church"] .goal-item,
html[data-skin="church"] .reflection-prompt,
html[data-skin="church"] .reflection-support-prompt,
html[data-skin="church"] .reflection-check-card,
html[data-skin="church"] .reflection-donation,
html[data-skin="church"] .media-overview,
html[data-skin="church"] .media-time-field,
html[data-skin="church"] .quick-note,
html[data-skin="church"] .quick-note-preview,
html[data-skin="church"] .quick-note-body,
html[data-skin="church"] .family-question-card,
html[data-skin="church"] .phase .school-presence {
    border: 4px solid var(--church-lead);
    border-radius: 3px;
    background:
        repeating-linear-gradient(90deg, rgba(26, 26, 26, 0.14) 0 2px, transparent 2px 46px),
        repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.16) 0 1px, transparent 1px 28px),
        linear-gradient(145deg, var(--church-parchment-strong), color-mix(in srgb, var(--church-column-glass, var(--member-color, var(--accent))) 24%, var(--church-parchment)));
    color: #15120e;
    box-shadow:
        0 5px 0 rgba(0, 0, 0, 0.34),
        0 10px 16px rgba(0, 0, 0, 0.28),
        inset 0 0 0 2px rgba(255, 247, 214, 0.24),
        inset 0 12px 18px rgba(255, 255, 255, 0.28),
        inset 0 -14px 22px rgba(0, 0, 0, 0.16);
}

html[data-skin="church"] .person-module {
    padding: 10px;
}

html[data-skin="church"] .phase {
    min-height: max(36px, calc(var(--appointment-phase-min-height) - 4px));
}

html[data-skin="church"] .appointment-title-toggle,
html[data-skin="church"] .goal-title-toggle,
html[data-skin="church"] .module-header h2,
html[data-skin="church"] .global-card h2,
html[data-skin="church"] .phase-title h3 {
    display: inline-flex;
    width: fit-content;
    padding: 2px 6px;
    border: 2px solid var(--church-lead);
    border-radius: 3px;
    background: rgba(244, 232, 209, 0.72);
    color: #15120e;
    font-family: "Cinzel", "Playfair Display", Georgia, serif;
    font-size: 0.74rem;
    font-weight: 900;
    letter-spacing: 0.02em;
    text-shadow: 0 1px 0 rgba(255, 246, 216, 0.52);
}

html[data-skin="church"] .task-text,
html[data-skin="church"] .goal-title,
html[data-skin="church"] .reflection-question,
html[data-skin="church"] .reflection-support-title,
html[data-skin="church"] .media-category-title,
html[data-skin="church"] .quick-note-preview,
html[data-skin="church"] .family-question-card {
    color: #15120e;
    font-family: "Segoe UI", Arial, sans-serif;
    font-weight: 700;
}

html[data-skin="church"] .task-item,
html[data-skin="church"] .task-list .task-item,
html[data-skin="church"] .appointments-module .task-list .task-item {
    background: transparent !important;
    border-color: transparent !important;
    box-shadow: none !important;
}

html[data-skin="church"] input,
html[data-skin="church"] textarea,
html[data-skin="church"] select {
    border: 3px solid var(--church-lead);
    border-radius: 4px;
    background:
        repeating-linear-gradient(90deg, rgba(26, 26, 26, 0.11) 0 2px, transparent 2px 54px),
        linear-gradient(145deg, rgba(252, 241, 214, 0.94), rgba(229, 210, 171, 0.84));
    color: #15120e;
    box-shadow:
        inset 0 2px 6px rgba(0, 0, 0, 0.22),
        inset 0 0 0 1px rgba(255, 255, 255, 0.38);
}

html[data-skin="church"] button,
html[data-skin="church"] .icon-button,
html[data-skin="church"] .icon-only,
html[data-skin="church"] .secondary-button,
html[data-skin="church"] .logout-link,
html[data-skin="church"] .global-head-toggle,
html[data-skin="church"] .family-highlight-counter,
html[data-skin="church"] .media-summary .media-chip,
html[data-skin="church"] .media-balance-pill,
html[data-skin="church"] .task-state,
html[data-skin="church"] .goal-status-toggle,
html[data-skin="church"] .reflection-item-toggle,
html[data-skin="church"] .reflection-write-toggle {
    border: 3px solid var(--church-lead);
    background:
        radial-gradient(circle at 34% 25%, rgba(255, 255, 255, 0.54), transparent 0 30%),
        linear-gradient(145deg, rgba(225, 199, 137, 0.92), rgba(114, 83, 48, 0.78));
    color: #15120e;
    box-shadow:
        0 4px 0 rgba(0, 0, 0, 0.34),
        0 8px 12px rgba(0, 0, 0, 0.24),
        inset 0 0 0 1px rgba(255, 242, 198, 0.28),
        inset 0 -8px 12px rgba(0, 0, 0, 0.18);
}

html[data-skin="church"] .family-upgrade-track,
html[data-skin="church"] .media-scale {
    border: 4px solid var(--church-lead);
    border-radius: 3px;
    background:
        repeating-linear-gradient(90deg, rgba(26, 26, 26, 0.48) 0 4px, transparent 4px 28px),
        linear-gradient(90deg, rgba(159, 26, 49, 0.75), rgba(240, 230, 202, 0.9) 50%, rgba(47, 164, 103, 0.82));
    box-shadow:
        inset 0 3px 8px rgba(0, 0, 0, 0.46),
        0 5px 0 rgba(0, 0, 0, 0.26);
}

html[data-skin="church"] .person-module.is-complete,
html[data-skin="church"] .appointments-module.is-empty-complete {
    border-color: var(--church-lead);
    box-shadow:
        0 0 0 3px color-mix(in srgb, var(--church-column-glass, var(--member-color)) 62%, rgba(255, 218, 112, 0.42)),
        0 6px 0 rgba(0, 0, 0, 0.38),
        0 15px 24px rgba(0, 0, 0, 0.36),
        inset 0 0 0 2px rgba(255, 243, 194, 0.3);
}

html[data-skin="church"] .person-module.earns-family-point,
html[data-skin="church"] .person-module.is-complete.earns-family-point,
html[data-skin="church"] .appointments-module.is-empty-complete.earns-family-point {
    border-color: var(--church-lead);
    box-shadow:
        0 0 0 5px color-mix(in srgb, var(--church-column-glass, var(--member-color)) 76%, rgba(255, 218, 112, 0.48)),
        0 8px 0 rgba(0, 0, 0, 0.4),
        0 18px 28px rgba(0, 0, 0, 0.42),
        inset 0 0 22px rgba(255, 233, 148, 0.26);
}

html[data-skin="church"] .family-point-links path {
    stroke-width: 5px;
    filter: drop-shadow(0 2px 1px rgba(0, 0, 0, 0.52));
}

/* Church asset scaffold: top cap image, repeatable middle pillar, bottom cap image. */
html[data-skin="church"] body {
    background-image:
        radial-gradient(circle at 50% -8%, rgba(230, 184, 97, 0.14), transparent 0 28%),
        linear-gradient(90deg, rgba(0, 0, 0, 0.48), transparent 18%, transparent 82%, rgba(0, 0, 0, 0.5)),
        url("stone-wall.jpg");
    background-size: auto, auto, cover;
    background-position: center;
    background-blend-mode: normal, multiply, multiply;
}

html[data-skin="church"] .church-column-part {
    display: block;
}

html[data-skin="church"] .church-top-cap,
html[data-skin="church"] .church-bottom-cap {
    position: relative;
    z-index: 2;
    flex: 0 0 auto;
    width: 100%;
    margin: 0;
    padding: 0;
    line-height: 0;
}

html[data-skin="church"] .church-top-cap {
    height: clamp(144px, 13.2vw, 192px);
    margin-bottom: -1px;
}

html[data-skin="church"] .church-bottom-cap {
    height: 48px;
    margin-top: -1px;
}

html[data-skin="church"] .church-top-cap img,
html[data-skin="church"] .church-bottom-cap img {
    display: block;
    width: 100%;
    height: 100%;
    margin: 0;
    object-fit: cover;
    object-position: center;
    user-select: none;
    pointer-events: none;
}

html[data-skin="church"] .church-avatar-medallion {
    position: absolute;
    top: 8px;
    left: 50%;
    display: grid;
    width: clamp(48px, 4.4vw, 66px);
    height: clamp(48px, 4.4vw, 66px);
    place-items: center;
    border: 6px solid #1a1a1a;
    border-radius: 50%;
    background:
        radial-gradient(circle at 36% 28%, rgba(255, 255, 255, 0.84), transparent 0 16%),
        radial-gradient(circle at center, rgba(244, 232, 209, 0.94), color-mix(in srgb, var(--member-color, var(--accent)) 42%, rgba(244, 232, 209, 0.82)));
    box-shadow:
        0 5px 0 rgba(0, 0, 0, 0.38),
        0 14px 18px rgba(0, 0, 0, 0.5),
        inset 0 0 0 3px rgba(255, 238, 174, 0.28),
        inset 0 -12px 18px rgba(0, 0, 0, 0.24);
    color: #15120e;
    font-family: "Cinzel", "Playfair Display", Georgia, serif;
    font-size: clamp(1.1rem, 1.7vw, 1.55rem);
    font-weight: 900;
    line-height: 1;
    text-shadow: 0 1px 0 rgba(255, 244, 210, 0.7);
    transform: translateX(-50%);
}

html[data-skin="church"] .church-middle-body {
    position: relative;
    z-index: 1;
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-height: 0;
    margin: 0;
    padding: 0 clamp(10px, 1.05vw, 18px);
    background:
        url("pillar-middle.png") repeat-y top center / 100% auto;
}

html[data-skin="church"] .member-column {
    display: flex;
    flex-direction: column;
    gap: 0;
    min-height: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    box-shadow:
        0 12px 0 rgba(0, 0, 0, 0.36),
        0 28px 40px rgba(0, 0, 0, 0.58),
        0 0 0 1px rgba(255, 230, 160, 0.08);
    filter: drop-shadow(0 10px 10px rgba(0, 0, 0, 0.5));
    overflow: visible;
    transform: none;
}

html[data-skin="church"] .member-column::before,
html[data-skin="church"] .member-column::after {
    display: none;
}

html[data-skin="church"] .member-header {
    position: relative;
    z-index: 3;
    flex: 0 0 auto;
    margin: clamp(-46px, -3.2vw, -34px) 0 6px;
    padding: 0 clamp(14px, 1.1vw, 22px);
}

html[data-skin="church"] .member-title h2 {
    width: fit-content;
    max-width: 100%;
    padding: 2px 5px;
    background: rgba(244, 232, 209, 0.58);
    border: 2px solid rgba(26, 26, 26, 0.88);
    color: #15120e;
}

html[data-skin="church"] .person-modules {
    position: relative;
    z-index: 2;
    display: grid;
    flex: 1 1 auto;
    gap: 7px;
    min-height: 0;
    max-height: 100%;
    padding: 0 clamp(8px, 0.7vw, 14px) 8px;
    overflow-x: visible;
    overflow-y: auto;
    scrollbar-color: rgba(26, 26, 26, 0.58) transparent;
    scrollbar-width: thin;
}

html[data-skin="church"] .person-modules::-webkit-scrollbar {
    width: 6px;
}

html[data-skin="church"] .person-modules::-webkit-scrollbar-thumb {
    border-radius: 0;
    background: rgba(26, 26, 26, 0.55);
}

html[data-skin="church"] .person-module,
html[data-skin="church"] .phase,
html[data-skin="church"] .task-list,
html[data-skin="church"] .goal-item,
html[data-skin="church"] .reflection-prompt,
html[data-skin="church"] .reflection-support-prompt,
html[data-skin="church"] .reflection-check-card,
html[data-skin="church"] .reflection-donation,
html[data-skin="church"] .media-overview,
html[data-skin="church"] .media-time-field,
html[data-skin="church"] .quick-note,
html[data-skin="church"] .quick-note-preview,
html[data-skin="church"] .quick-note-body,
html[data-skin="church"] .family-question-card,
html[data-skin="church"] .phase .school-presence {
    border: 4px solid #1a1a1a;
    border-radius: 2px;
    background:
        linear-gradient(145deg, rgba(244, 232, 209, 0.9), rgba(218, 197, 154, 0.78)),
        color-mix(in srgb, var(--member-color, var(--accent)) 12%, rgba(244, 232, 209, 0.84));
}

html[data-skin="church"] .phase,
html[data-skin="church"] .goal-item,
html[data-skin="church"] .reflection-prompt,
html[data-skin="church"] .reflection-support-prompt,
html[data-skin="church"] .media-time-field {
    margin-block: 2px;
}

@media (min-width: 761px) {
    html[data-skin="church"],
    html[data-skin="church"] body {
        height: 100%;
        overflow: hidden;
    }

    html[data-skin="church"] .app-shell {
        display: flex;
        height: 100vh;
        max-height: 100vh;
        flex-direction: column;
        overflow: hidden;
    }

    html[data-skin="church"] .top-dashboard {
        flex: 0 0 auto;
        margin-bottom: 10px;
    }

    html[data-skin="church"] .board {
        display: grid;
        flex: 1 1 auto;
        grid-template-columns: repeat(var(--member-count, 5), minmax(0, 1fr));
        gap: clamp(14px, 1.4vw, 24px);
        min-height: 0;
        height: auto;
        margin: 0;
        overflow: visible;
        border: 0;
        background: transparent;
    }

    html[data-skin="church"] .member-column {
        width: auto;
        min-width: 0;
        max-width: none;
        height: 100%;
        scroll-snap-align: none;
    }
}

@media (max-width: 760px) {
    html[data-skin="church"] .church-top-cap {
        height: 138px;
    }

    html[data-skin="church"] .church-bottom-cap {
        height: 40px;
    }

    html[data-skin="church"] .member-header {
        margin-top: -28px;
    }
}

/* Appointment rows: the interactive hitbox must stay invisible in every skin. */
.appointments-module .task-list .task-item,
.appointments-module .task-list .task-item:hover,
.appointments-module .task-list .task-item.open,
.appointments-module .task-list .task-item.done,
.appointments-module .task-list .task-item.skipped {
    border-color: transparent !important;
    background: transparent !important;
    box-shadow: none !important;
}

.appointments-module .task-list .task-state {
    box-shadow: none !important;
}

.appointments-module .task-list .task-item.done .task-state {
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) 82%, #ffffff);
    background: color-mix(in srgb, var(--member-color, var(--accent)) 82%, #ffffff);
}

.appointments-module .task-list {
    gap: var(--appointment-line-gap);
    margin-top: max(0px, calc(1px + var(--ui-line-extra)));
}

.appointments-module .phase {
    min-height: var(--appointment-phase-min-height);
    padding-block: var(--appointment-phase-pad-y);
}

.appointments-module .task-list .task-item {
    min-height: var(--appointment-line-height);
    padding-block: 2px;
    align-items: center;
    line-height: 1.2;
}

.appointments-module .task-list .task-title {
    line-height: 1.24;
}

.appointments-module .task-list .task-state {
    width: 11px;
    min-width: 11px;
    height: 11px;
}

@media (max-width: 760px) {
    html[data-skin="kids"] .app-shell::before,
    html[data-skin="metal"] .app-shell::before,
    html[data-skin="zen"] body::before,
    html[data-skin="zen"] body::after,
    html[data-skin="frosted"] body::before,
    html[data-skin="frosted"] body::after,
    html[data-skin="church"] body::before,
    html[data-skin="church"] body::after {
        opacity: 0.34;
    }

    html[data-skin="kids"] .member-column {
        padding-top: calc(var(--layout-column-pad) + 12px);
        transform: none;
    }

    html[data-skin="kids"] .member-column::before {
        top: -10px;
        left: auto;
        right: 18px;
        width: 42px;
        height: 42px;
        border-width: 4px;
        font-size: 1.2rem;
        transform: rotate(5deg);
    }

    html[data-skin="metal"] .app-shell::before {
        inset: 4px;
        border-radius: 12px;
    }

    html[data-skin="church"] .top-dashboard,
    html[data-skin="church"] .topbar,
    html[data-skin="church"] .global-card {
        border-width: 3px;
        border-radius: 22px 22px 8px 8px;
    }

    html[data-skin="church"] .member-column {
        padding-top: calc(var(--layout-column-pad) + 16px);
        border-width: 4px;
        border-radius: 58px 58px 14px 14px;
    }

    html[data-skin="church"] .member-column::before {
        top: 12px;
        width: 42px;
        height: 42px;
        border-width: 4px;
    }

    html[data-skin="church"] .person-module,
    html[data-skin="church"] .phase,
    html[data-skin="church"] .goal-item,
    html[data-skin="church"] .reflection-prompt,
    html[data-skin="church"] .reflection-support-prompt,
    html[data-skin="church"] .media-overview,
    html[data-skin="church"] .media-time-field {
        border-width: 2px;
    }
}

.settings-inline-form.dark-mode-settings-form {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.settings-inline-form.dark-mode-settings-form button {
    grid-column: auto;
}

@media (max-width: 760px) {
    .settings-inline-form.dark-mode-settings-form {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .settings-inline-form.dark-mode-settings-form button {
        grid-column: 1 / -1;
    }
}

/* Kids skin rework: pastel sticker dashboard with larger, friendlier interaction targets. */
html[data-skin="kids"] {
    --kids-ink: #233244;
    --kids-muted: #657586;
    --kids-paper: rgba(255, 255, 255, 0.78);
    --kids-paper-strong: rgba(255, 255, 255, 0.9);
    --kids-shadow: 0 18px 32px rgba(46, 61, 78, 0.16);
    --kids-sticker-shadow: 0 5px 0 rgba(255, 255, 255, 0.94), 0 13px 22px rgba(44, 58, 74, 0.22);
    --kids-radius: 24px;
    --kids-blue: #9bd8ff;
    --kids-green: #9ee6bd;
    --kids-apricot: #ffc579;
    --kids-lavender: #dda1ef;
    --kids-purple: #b79aea;
    --kids-body-font: "Letters for Learners", "Comic Sans MS", "Segoe UI Rounded", "Arial Rounded MT Bold", "Segoe UI", system-ui, sans-serif;
    font-family: "Nunito", "Segoe UI Rounded", "Arial Rounded MT Bold", "Segoe UI", system-ui, sans-serif;
}

html[data-skin="kids"] body {
    background-color: #dcfb6c;
    background-image:
        radial-gradient(circle at 9% 21%, rgba(255, 255, 255, 0.68) 0 18px, transparent 19px),
        radial-gradient(circle at 88% 18%, rgba(255, 194, 100, 0.34) 0 24px, transparent 25px),
        radial-gradient(circle at 17% 92%, rgba(126, 213, 255, 0.34) 0 28px, transparent 29px),
        linear-gradient(45deg, rgba(188, 231, 45, 0.42) 25%, transparent 25% 75%, rgba(188, 231, 45, 0.42) 75%),
        linear-gradient(45deg, rgba(255, 255, 255, 0.42) 25%, transparent 25% 75%, rgba(255, 255, 255, 0.42) 75%),
        linear-gradient(135deg, #f4ffd5 0%, #ddfa6c 48%, #ccf152 100%);
    background-position: 0 0, 0 0, 0 0, 0 0, 42px 42px, 0 0;
    background-size: auto, auto, auto, 84px 84px, 84px 84px, auto;
    color: var(--kids-ink);
}

html[data-skin="kids"] body::before {
    display: block;
    inset: 0;
    opacity: 0.7;
    background:
        radial-gradient(circle at 3.5% 33%, #fff8ca 0 22px, #f5c64b 23px 35px, #ffffff 36px 43px, transparent 44px),
        radial-gradient(circle at 95% 36%, #fce7df 0 24px, #e86b6e 25px 38px, #ffffff 39px 47px, transparent 48px),
        radial-gradient(circle at 13% 94%, #fff3b8 0 25px, #efbd3b 26px 42px, #ffffff 43px 52px, transparent 53px),
        radial-gradient(circle at 88% 91%, #eef1ff 0 22px, #9c86dc 23px 38px, #ffffff 39px 48px, transparent 49px);
    filter: drop-shadow(0 12px 16px rgba(41, 53, 69, 0.18));
}

html[data-skin="kids"] body::after {
    display: block;
    inset: 88px 38px auto;
    height: min(76vh, 760px);
    border: 0;
    border-radius: 34px;
    background:
        radial-gradient(circle at 6% 76%, rgba(255, 255, 255, 0.62) 0 22px, transparent 23px),
        radial-gradient(circle at 87% 16%, rgba(255, 255, 255, 0.52) 0 18px, transparent 19px),
        rgba(255, 255, 255, 0.16);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
    opacity: 0.72;
}

html[data-skin="kids"] .app-shell {
    isolation: isolate;
}

html[data-skin="kids"] .app-shell::before {
    display: block;
    inset: 0;
    z-index: -1;
    opacity: 1;
    background:
        conic-gradient(from -18deg at 5% 45%, transparent 0 15%, #ffffff 15% 21%, #5eb7e8 21% 39%, #ef6e62 39% 48%, #ffffff 48% 56%, transparent 56%),
        radial-gradient(circle at 9% 47%, #6fc6ef 0 13px, #ffffff 14px 18px, transparent 19px),
        conic-gradient(from 45deg at 91% 33%, transparent 0 16%, #ffffff 16% 24%, #ef6d65 24% 42%, #69c0ec 42% 56%, #ffffff 56% 64%, transparent 64%),
        radial-gradient(circle at 85% 84%, #fff6b9 0 12px, #f1bf38 13px 26px, #ffffff 27px 34px, transparent 35px),
        radial-gradient(circle at 18% 88%, #b8e8ff 0 12px, #52a9d7 13px 24px, #ffffff 25px 31px, transparent 32px);
    background-repeat: no-repeat;
    filter: drop-shadow(0 12px 12px rgba(43, 57, 73, 0.16));
    pointer-events: none;
}

html[data-skin="kids"] .top-dashboard {
    gap: 16px;
}

html[data-skin="kids"] .topbar,
html[data-skin="kids"] .global-card,
html[data-skin="kids"] .family-upgrades-card {
    border: 3px solid rgba(255, 255, 255, 0.9);
    border-radius: 28px;
    background:
        linear-gradient(150deg, rgba(255, 255, 241, 0.94), rgba(255, 255, 255, 0.66)),
        rgba(255, 255, 255, 0.62);
    box-shadow: var(--kids-shadow), inset 0 2px 0 rgba(255, 255, 255, 0.94);
    color: var(--kids-ink);
}

html[data-skin="kids"] .top-dashboard {
    border: 0;
    background: transparent;
    box-shadow: none;
}

html[data-skin="kids"] .daybar,
html[data-skin="kids"] .topbar-actions {
    gap: 8px;
    min-height: 68px;
    padding: 8px 10px;
    border: 3px solid rgba(255, 255, 255, 0.92);
    border-radius: 24px;
    background:
        linear-gradient(150deg, rgba(255, 255, 242, 0.96), rgba(255, 255, 255, 0.84)),
        rgba(255, 255, 255, 0.84);
    box-shadow: var(--kids-shadow), inset 0 2px 0 rgba(255, 255, 255, 0.96);
}

html[data-skin="kids"] .topbar-actions {
    justify-content: center;
}

html[data-skin="kids"] .date-display-text,
html[data-skin="kids"] .today-compact,
html[data-skin="kids"] .topbar .icon-button,
html[data-skin="kids"] .topbar .logout-link,
html[data-skin="kids"] .family-highlight-counter {
    border: 2px solid rgba(36, 49, 66, 0.1);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.78);
    color: var(--kids-ink);
    box-shadow: 0 4px 0 rgba(47, 62, 81, 0.07), inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

html[data-skin="kids"] .date-display-text {
    font-weight: 850;
}

html[data-skin="kids"] .family-upgrades-bar {
    border: 2px solid rgba(40, 57, 72, 0.14);
    background: rgba(255, 255, 255, 0.72);
    box-shadow: inset 0 2px 3px rgba(47, 62, 81, 0.12);
}

html[data-skin="kids"] .family-upgrades-card {
    min-height: 68px;
    padding: 9px 14px;
}

html[data-skin="kids"] .family-upgrades-fill,
html[data-skin="kids"] .family-upgrades-today-fill {
    background: #66ccb1;
}

html[data-skin="kids"] .family-upgrade-track {
    height: 27px;
    border: 3px solid rgba(38, 51, 67, 0.14);
    border-radius: 999px;
    background:
        linear-gradient(90deg, rgba(101, 204, 177, 0.12), rgba(255, 255, 255, 0.72) 50%, rgba(101, 204, 177, 0.2)),
        rgba(255, 255, 255, 0.68);
    box-shadow: inset 0 2px 4px rgba(40, 54, 70, 0.12), 0 4px 0 rgba(44, 58, 74, 0.05);
}

html[data-skin="kids"] .family-upgrade-fill-lane {
    inset: 5px;
}

html[data-skin="kids"] .family-upgrade-segment-before {
    background: #bfe7d5;
}

html[data-skin="kids"] .family-upgrade-segment-today {
    background: #63cba2;
}

html[data-skin="kids"] .family-upgrade-mark i {
    width: 2px;
    background: rgba(39, 53, 69, 0.28);
}

html[data-skin="kids"] .family-upgrade-mark.is-reached i {
    background: #37aa7e;
}

html[data-skin="kids"] .global-module-strip {
    gap: 16px;
}

html[data-skin="kids"] .global-card {
    min-height: 118px;
    padding: 14px 16px;
}

html[data-skin="kids"] .global-card h2,
html[data-skin="kids"] .module-header h2,
html[data-skin="kids"] .appointment-title-toggle,
html[data-skin="kids"] .goal-title-toggle,
html[data-skin="kids"] .phase-title h3 {
    color: var(--kids-ink);
    font-size: 0.84rem;
    font-weight: 900;
    letter-spacing: 0.035em;
    text-transform: uppercase;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.88);
}

html[data-skin="kids"] .board {
    gap: 16px;
    padding-top: 58px;
    overflow-y: visible;
}

html[data-skin="kids"] .member-column {
    --kids-line: color-mix(in srgb, var(--member-color, var(--accent)) 68%, #2b3441);
    --kids-panel: color-mix(in srgb, var(--member-color, var(--accent)) 38%, #ffffff);
    --kids-panel-soft: color-mix(in srgb, var(--member-color, var(--accent)) 19%, #ffffff);
    padding: 62px 16px 18px;
    border: 4px solid var(--kids-line);
    border-radius: 24px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.36), rgba(255, 255, 255, 0.08)),
        var(--kids-panel);
    box-shadow:
        0 7px 0 color-mix(in srgb, var(--kids-line) 58%, rgba(255, 255, 255, 0.34)),
        0 22px 34px rgba(39, 52, 68, 0.18),
        inset 0 2px 0 rgba(255, 255, 255, 0.72);
    transform: none;
    overflow: visible;
}

html[data-skin="kids"] .member-column:nth-child(5n+1) {
    --kids-line: #2f83bc;
    --kids-panel: #94d2f8;
    --kids-panel-soft: #d4efff;
    --kids-avatar: "\1F989";
}

html[data-skin="kids"] .member-column:nth-child(5n+2) {
    --kids-line: #2f9f6e;
    --kids-panel: #95e1b6;
    --kids-panel-soft: #d8f7e6;
    --kids-avatar: "\1F43B";
}

html[data-skin="kids"] .member-column:nth-child(5n+3) {
    --kids-line: #cf781e;
    --kids-panel: #ffc57c;
    --kids-panel-soft: #ffe4bb;
    --kids-avatar: "\1F981";
}

html[data-skin="kids"] .member-column:nth-child(5n+4) {
    --kids-line: #a54dba;
    --kids-panel: #dda1ed;
    --kids-panel-soft: #f2d5f8;
    --kids-avatar: "\1F430";
}

html[data-skin="kids"] .member-column:nth-child(5n) {
    --kids-line: #7b55b9;
    --kids-panel: #bea2f2;
    --kids-panel-soft: #e7dbff;
    --kids-avatar: "\1F431";
}

html[data-skin="kids"] .member-column::before {
    top: -54px;
    left: 50%;
    right: auto;
    z-index: 6;
    width: 108px;
    height: 108px;
    border: 7px solid #ffffff;
    border-radius: 999px;
    content: var(--kids-avatar, "\2726");
    background:
        radial-gradient(circle at 32% 25%, rgba(255, 255, 255, 0.9) 0 16%, transparent 17%),
        radial-gradient(circle at 50% 62%, rgba(255, 255, 255, 0.3), transparent 55%),
        var(--kids-panel-soft);
    box-shadow: var(--kids-sticker-shadow);
    color: var(--kids-ink);
    font-family: "Segoe UI Emoji", "Apple Color Emoji", "Noto Color Emoji", sans-serif;
    font-size: 3.45rem;
    font-weight: 700;
    line-height: 1;
    transform: translateX(-50%) rotate(-2deg);
}

html[data-skin="kids"] .member-column[data-has-avatar="true"]::before {
    content: "";
    background:
        var(--member-avatar-image) center / 78% 78% no-repeat,
        radial-gradient(circle at 32% 25%, rgba(255, 255, 255, 0.9) 0 16%, transparent 17%),
        radial-gradient(circle at 50% 62%, rgba(255, 255, 255, 0.3), transparent 55%),
        var(--kids-panel-soft);
    font-size: 0;
}

html[data-skin="kids"] .member-column::after {
    position: absolute;
    top: 34px;
    left: 50%;
    z-index: 5;
    width: 46px;
    height: 12px;
    border-radius: 999px;
    content: "";
    background: rgba(255, 255, 255, 0.34);
    filter: blur(3px);
    transform: translateX(-50%);
}

html[data-skin="kids"] .member-header {
    margin: 0 0 12px;
    padding: 0;
}

html[data-skin="kids"] .member-title h2 {
    color: #182233;
    font-size: clamp(1.45rem, 1.05rem + 0.9vw, 2.1rem);
    font-weight: 950;
    letter-spacing: 0;
    line-height: 1.05;
    text-shadow:
        0 3px 0 #ffffff,
        2px 0 0 #ffffff,
        -2px 0 0 #ffffff,
        0 7px 8px rgba(31, 42, 55, 0.2);
}

html[data-skin="kids"] .flagged-chip,
html[data-skin="kids"] .member-reminders {
    color: #203044;
    font-size: 0.86rem;
    font-weight: 760;
}

html[data-skin="kids"] .person-module,
html[data-skin="kids"] .appointments-module,
html[data-skin="kids"] .goals-module,
html[data-skin="kids"] .reflection-module,
html[data-skin="kids"] .family-question-module,
html[data-skin="kids"] .reflection-donation-module,
html[data-skin="kids"] .media-module {
    border: 0;
    border-radius: 20px;
    padding: 14px;
    background: color-mix(in srgb, var(--kids-panel-soft) 66%, rgba(255, 255, 255, 0.58));
    box-shadow:
        inset 0 2px 0 rgba(255, 255, 255, 0.74),
        0 9px 16px rgba(36, 48, 63, 0.1);
    transition: transform 180ms cubic-bezier(0.2, 1.2, 0.25, 1), box-shadow 180ms ease;
}

html[data-skin="kids"] .person-module:hover,
html[data-skin="kids"] .global-card:hover {
    box-shadow:
        inset 0 2px 0 rgba(255, 255, 255, 0.78),
        0 14px 24px rgba(36, 48, 63, 0.14);
}

html[data-skin="kids"] .person-module:hover {
    transform: none;
}

html[data-skin="kids"] .person-module.is-complete,
html[data-skin="kids"] .appointments-module.is-empty-complete,
html[data-skin="kids"] .person-module.earns-family-point,
html[data-skin="kids"] .person-module.is-complete.earns-family-point,
html[data-skin="kids"] .appointments-module.is-empty-complete.earns-family-point {
    border: 3px solid var(--kids-line);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.62), rgba(255, 255, 255, 0.36)),
        color-mix(in srgb, var(--kids-panel-soft) 82%, #ffffff);
    box-shadow:
        inset 0 2px 0 rgba(255, 255, 255, 0.82),
        0 0 0 4px rgba(255, 255, 255, 0.62),
        0 14px 22px color-mix(in srgb, var(--kids-line) 28%, transparent);
}

html[data-skin="kids"] .module-header,
html[data-skin="kids"] .goals-header,
html[data-skin="kids"] .appointments-module .module-header {
    margin-bottom: 7px;
    border: 0;
    padding: 0;
    background: transparent;
}

html[data-skin="kids"] .phase,
html[data-skin="kids"] .appointments-module .phase {
    border: 3px solid color-mix(in srgb, var(--kids-line) 50%, #ffffff);
    border-radius: 18px;
    padding: 10px 11px;
    background: rgba(255, 255, 255, 0.52);
    box-shadow: inset 0 2px 0 rgba(255, 255, 255, 0.68);
}

html[data-skin="kids"] .phase-title {
    color: color-mix(in srgb, var(--kids-line) 70%, #243244);
}

html[data-skin="kids"] .appointments-module .task-list {
    gap: 5px;
}

html[data-skin="kids"] .appointments-module .task-list .task-item,
html[data-skin="kids"] .appointments-module .task-list .task-item:hover,
html[data-skin="kids"] .appointments-module .task-list .task-item.open,
html[data-skin="kids"] .appointments-module .task-list .task-item.done,
html[data-skin="kids"] .appointments-module .task-list .task-item.skipped,
html[data-skin="kids"] .task-item,
html[data-skin="kids"] .goal-item,
html[data-skin="kids"] .reflection-prompt,
html[data-skin="kids"] .reflection-support-prompt,
html[data-skin="kids"] .reflection-check-card,
html[data-skin="kids"] .family-question-card {
    min-height: 42px;
    border: 3px solid color-mix(in srgb, var(--kids-line) 52%, #ffffff) !important;
    border-radius: 16px;
    padding: 8px 10px;
    background: rgba(255, 255, 255, 0.78) !important;
    box-shadow:
        inset 0 2px 0 rgba(255, 255, 255, 0.9),
        0 5px 0 rgba(45, 58, 72, 0.05) !important;
}

html[data-skin="kids"] .appointments-module .task-list .task-item.done,
html[data-skin="kids"] .goal-item.done,
html[data-skin="kids"] .reflection-prompt.is-done,
html[data-skin="kids"] .reflection-support-prompt.is-done {
    background: color-mix(in srgb, var(--kids-panel-soft) 58%, rgba(255, 255, 255, 0.86)) !important;
}

html[data-skin="kids"] .task-title,
html[data-skin="kids"] .goal-text,
html[data-skin="kids"] .reflection-prompt,
html[data-skin="kids"] .reflection-support-prompt {
    color: var(--kids-ink);
    font-size: 0.9rem;
    line-height: 1.25;
}

html[data-skin="kids"] .task-title,
html[data-skin="kids"] .goal-main,
html[data-skin="kids"] .goal-text,
html[data-skin="kids"] .flagged-chip,
html[data-skin="kids"] .member-reminders,
html[data-skin="kids"] .reflection-intro-note,
html[data-skin="kids"] .reflection-question,
html[data-skin="kids"] .reflection-support-prompt p,
html[data-skin="kids"] .reflection-prompt p,
html[data-skin="kids"] .family-question-card p,
html[data-skin="kids"] .media-summary,
html[data-skin="kids"] .media-time-info,
html[data-skin="kids"] .global-card p,
html[data-skin="kids"] .global-list,
html[data-skin="kids"] textarea,
html[data-skin="kids"] input {
    font-family: var(--kids-body-font);
}

html[data-skin="kids"] .task-item,
html[data-skin="kids"] .goal-item,
html[data-skin="kids"] .reflection-card-head {
    column-gap: 9px;
}

html[data-skin="kids"] .task-title,
html[data-skin="kids"] .goal-main,
html[data-skin="kids"] .reflection-prompt-title,
html[data-skin="kids"] .reflection-question {
    padding-right: 6px;
}

html[data-skin="kids"] .task-menu-toggle,
html[data-skin="kids"] .goal-edit-toggle,
html[data-skin="kids"] .reflection-write-toggle {
    margin-left: 4px;
}

html[data-skin="kids"] .task-state,
html[data-skin="kids"] .goal-status-toggle,
html[data-skin="kids"] .reflection-item-toggle,
html[data-skin="kids"] .reflection-write-toggle {
    width: 32px !important;
    min-width: 32px !important;
    height: 32px !important;
    min-height: 32px !important;
    border: 3px solid color-mix(in srgb, var(--kids-line) 42%, #ffffff) !important;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    color: color-mix(in srgb, var(--kids-line) 78%, var(--kids-ink));
    box-shadow: inset 0 2px 0 rgba(255, 255, 255, 0.88), 0 4px 0 rgba(35, 47, 61, 0.06) !important;
    transition:
        transform 220ms cubic-bezier(0.2, 1.45, 0.3, 1),
        background 160ms ease,
        border-color 160ms ease;
}

html[data-skin="kids"] .task-item.done .task-state,
html[data-skin="kids"] .goal-item.done .goal-status-toggle,
html[data-skin="kids"] .goal-item.tried .goal-status-toggle,
html[data-skin="kids"] .reflection-item-toggle[aria-pressed="true"] {
    border-color: color-mix(in srgb, var(--kids-line) 72%, #ffffff) !important;
    background: color-mix(in srgb, var(--kids-panel) 52%, #ffffff);
    transform: scale(1.06) rotate(-5deg);
}

html[data-skin="kids"] .goal-week-dots i,
html[data-skin="kids"] .media-week-history i {
    width: 9px;
    height: 9px;
    border-width: 2px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

html[data-skin="kids"] .media-overview {
    position: relative;
    border: 0;
    border-radius: 18px;
    padding: 10px 11px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(255, 255, 255, 0.58)),
        var(--kids-panel-soft);
    box-shadow: inset 0 2px 0 rgba(255, 255, 255, 0.9), 0 7px 14px rgba(38, 50, 64, 0.09);
}

html[data-skin="kids"] .media-overview::after {
    position: absolute;
    top: 7px;
    right: 18px;
    z-index: 3;
    width: 30px;
    height: 19px;
    border: 3px solid #ffffff;
    border-radius: 999px 999px 8px 8px;
    content: "";
    background:
        radial-gradient(circle at 25% 100%, #31445a 0 3px, #ffffff 4px 6px, transparent 7px),
        radial-gradient(circle at 75% 100%, #31445a 0 3px, #ffffff 4px 6px, transparent 7px),
        linear-gradient(90deg, color-mix(in srgb, var(--kids-line) 58%, #ffffff), var(--kids-panel));
    box-shadow: 0 6px 0 rgba(42, 55, 70, 0.08), 0 9px 13px rgba(42, 55, 70, 0.16);
    transform: rotate(-2deg);
}

html[data-skin="kids"] .media-scale {
    height: 28px;
    border: 3px solid #6f5945;
    border-radius: 999px;
    background:
        repeating-linear-gradient(90deg, rgba(70, 55, 43, 0.48) 0 3px, transparent 3px 17px),
        linear-gradient(180deg, transparent 0 36%, rgba(70, 55, 43, 0.38) 36% 45%, transparent 45% 55%, rgba(70, 55, 43, 0.38) 55% 64%, transparent 64%),
        linear-gradient(90deg, #f3a3ab 0%, #fff3d0 48%, #8de0bf 100%);
    box-shadow:
        inset 0 2px 2px rgba(255, 255, 255, 0.5),
        inset 0 -2px 2px rgba(69, 52, 40, 0.18);
}

html[data-skin="kids"] .media-scale::after {
    top: 3px;
    bottom: 3px;
    width: 2px;
    background: rgba(72, 56, 42, 0.34);
}

html[data-skin="kids"] .media-balance-pill {
    min-width: 42px;
    border: 3px solid rgba(255, 255, 255, 0.92);
    background: rgba(255, 255, 255, 0.92);
    color: var(--kids-ink);
    font-size: 0.78rem;
    font-weight: 950;
    box-shadow: 0 5px 0 rgba(58, 71, 87, 0.09), 0 8px 14px rgba(58, 71, 87, 0.14);
}

html[data-skin="kids"] .media-balance-pill.is-debt {
    color: #a85058;
}

html[data-skin="kids"] .media-balance-pill.is-credit,
html[data-skin="kids"] .media-balance-pill.is-neutral {
    color: #32775c;
}

html[data-skin="kids"] .media-summary {
    gap: 6px;
}

html[data-skin="kids"] .media-summary .media-chip,
html[data-skin="kids"] .family-highlight-counter,
html[data-skin="kids"] .icon-button,
html[data-skin="kids"] .icon-only,
html[data-skin="kids"] .secondary-button,
html[data-skin="kids"] .global-head-toggle,
html[data-skin="kids"] .goal-edit-toggle,
html[data-skin="kids"] .reflection-write-toggle,
html[data-skin="kids"] .task-menu-toggle {
    border: 2px solid rgba(38, 51, 67, 0.09);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    color: color-mix(in srgb, var(--kids-line, var(--accent)) 62%, var(--kids-ink));
    box-shadow: 0 4px 0 rgba(39, 52, 67, 0.06), inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

html[data-skin="kids"] .media-time-field {
    grid-template-columns: minmax(0, 1fr) minmax(94px, max-content);
    border: 0;
    border-radius: 18px;
    padding: 10px 12px;
    background: rgba(255, 255, 255, 0.72);
    box-shadow: inset 0 2px 0 rgba(255, 255, 255, 0.86), 0 5px 0 rgba(45, 58, 72, 0.045);
}

html[data-skin="kids"] .media-time-info strong,
html[data-skin="kids"] .media-field-title {
    color: color-mix(in srgb, var(--kids-line) 72%, var(--kids-ink));
    font-size: 0.92rem;
    font-weight: 900;
}

html[data-skin="kids"] .media-time-info small,
html[data-skin="kids"] .media-bonus-description {
    color: var(--kids-muted);
    font-size: 0.8rem;
    line-height: 1.25;
}

html[data-skin="kids"] .media-stepper-display,
html[data-skin="kids"] .media-stepper button {
    border: 2px solid rgba(38, 51, 67, 0.08);
    background: rgba(255, 255, 255, 0.86);
    color: var(--kids-ink);
    font-weight: 850;
}

html[data-skin="kids"] .reflection-intro-note {
    color: var(--kids-muted);
    font-size: 0.82rem;
}

html[data-skin="kids"] .reflection-prompt-title,
html[data-skin="kids"] .reflection-question,
html[data-skin="kids"] .family-question-card {
    color: var(--kids-ink);
}

html[data-skin="kids"] textarea,
html[data-skin="kids"] input[type="text"],
html[data-skin="kids"] input[type="number"],
html[data-skin="kids"] input[type="time"],
html[data-skin="kids"] .time-button,
html[data-skin="kids"] .presence-time-trigger,
html[data-skin="kids"] .meal-input,
html[data-skin="kids"] .day-name-input,
html[data-skin="kids"] .global-card input,
html[data-skin="kids"] .global-card textarea {
    border: 3px solid rgba(40, 54, 70, 0.12);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.84);
    color: var(--kids-ink);
    box-shadow: inset 0 2px 0 rgba(255, 255, 255, 0.88);
}

html[data-skin="kids"] .phase .school-presence,
html[data-skin="kids"] .module-header .school-presence,
html[data-skin="kids"] .school-presence,
html[data-skin="kids"] .school-presence-display,
html[data-skin="kids"] .school-presence-display.has-override,
html[data-skin="kids"] .school-schedule-toggle,
html[data-skin="kids"] .presence-defaults-toggle {
    border-color: transparent !important;
    background: transparent !important;
    box-shadow: none !important;
}

html[data-skin="kids"] .school-presence-display:focus-visible,
html[data-skin="kids"] .school-schedule-toggle:focus-visible,
html[data-skin="kids"] .presence-defaults-toggle:focus-visible {
    outline: 0;
}

html[data-skin="kids"] .school-presence {
    gap: 8px;
    padding: 0 2px;
}

html[data-skin="kids"] .school-presence-display span {
    color: color-mix(in srgb, var(--kids-line) 68%, var(--kids-ink));
}

html[data-skin="kids"] .family-point-links path {
    stroke-width: 4px;
    opacity: 0.88;
    filter:
        drop-shadow(0 2px 0 rgba(255, 255, 255, 0.9))
        drop-shadow(0 8px 6px rgba(38, 51, 67, 0.18));
}

html[data-skin="kids"] .family-point-links.is-over {
    z-index: 60;
}

html[data-skin="kids"] .family-point-links.is-under {
    z-index: 2;
}

html[data-skin="kids"] .member-column {
    z-index: 5;
}

html[data-skin="kids"] .member-column.is-floating-host {
    z-index: 140;
}

html[data-skin="kids"] .person-task-form[data-floating="true"],
html[data-skin="kids"] .task-edit-panel[data-floating="true"],
html[data-skin="kids"] .school-schedule-form[data-floating="true"] {
    border-width: 3px;
    border-color: color-mix(in srgb, var(--kids-line, var(--member-color, var(--accent))) 50%, #ffffff);
    border-radius: 20px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.97), rgba(255, 255, 255, 0.9)),
        color-mix(in srgb, var(--kids-panel-soft, var(--member-color, var(--accent))) 28%, #ffffff);
    box-shadow:
        0 20px 44px rgba(37, 49, 64, 0.22),
        0 0 0 4px rgba(255, 255, 255, 0.58),
        inset 0 2px 0 rgba(255, 255, 255, 0.92);
    transform: none !important;
}

@media (prefers-reduced-motion: no-preference) {
    html[data-skin="kids"] .task-state:hover,
    html[data-skin="kids"] .goal-status-toggle:hover,
    html[data-skin="kids"] .reflection-item-toggle:hover,
    html[data-skin="kids"] .reflection-write-toggle:hover {
        transform: scale(1.12) rotate(-4deg);
    }

    html[data-skin="kids"] .icon-button:hover,
    html[data-skin="kids"] .secondary-button:hover,
    html[data-skin="kids"] .task-menu-toggle:hover,
    html[data-skin="kids"] .goal-edit-toggle:hover {
        transform: translateY(-2px) rotate(-1deg);
    }
}

@media (max-width: 760px) {
    html[data-skin="kids"] body::after {
        inset: 54px 14px auto;
        height: min(82vh, 820px);
        border-radius: 24px;
    }

    html[data-skin="kids"] .app-shell::before {
        opacity: 0.38;
        background-size: 110px 110px, auto, 110px 110px, auto, auto;
    }

    html[data-skin="kids"] .top-dashboard,
    html[data-skin="kids"] .topbar,
    html[data-skin="kids"] .global-card,
    html[data-skin="kids"] .family-upgrades-card {
        border-width: 2px;
        border-radius: 24px;
    }

    html[data-skin="kids"] .board {
        padding-top: 42px;
    }

    html[data-skin="kids"] .app-shell.is-swipe-layout .member-column {
        padding: 50px 14px 16px;
        border-width: 3px;
    }

    html[data-skin="kids"] .member-column::before {
        top: -38px;
        right: 18px;
        left: auto;
        width: 78px;
        height: 78px;
        border-width: 5px;
        font-size: 2.45rem;
        transform: rotate(4deg);
    }

    html[data-skin="kids"] .member-column::after {
        top: 24px;
        right: 34px;
        left: auto;
        transform: none;
    }

    html[data-skin="kids"] .member-title h2 {
        max-width: calc(100% - 84px);
        font-size: 1.45rem;
    }

    html[data-skin="kids"] .person-module,
    html[data-skin="kids"] .appointments-module,
    html[data-skin="kids"] .goals-module,
    html[data-skin="kids"] .reflection-module,
    html[data-skin="kids"] .family-question-module,
    html[data-skin="kids"] .reflection-donation-module,
    html[data-skin="kids"] .media-module {
        padding: 12px;
        border-radius: 19px;
    }

    html[data-skin="kids"] .global-card {
        min-height: 132px;
        padding: 14px;
    }

    html[data-skin="kids"] .task-title,
    html[data-skin="kids"] .goal-text,
    html[data-skin="kids"] .reflection-prompt,
    html[data-skin="kids"] .reflection-support-prompt {
        font-size: 0.86rem;
    }
}

/* Standard skin: stronger layer hierarchy for custom wallpapers. */
html[data-theme="light"][data-skin="standard"] .topbar,
html[data-theme="light"][data-skin="standard"] .top-dashboard .daybar,
html[data-theme="light"][data-skin="standard"] .top-dashboard .topbar-actions,
html[data-theme="light"][data-skin="standard"] .global-card,
html[data-theme="light"][data-skin="standard"] .family-upgrades-card {
    border: 1px solid color-mix(in srgb, var(--top-module-color, #ffffff) 28%, rgba(37, 47, 56, 0.105));
    background:
        linear-gradient(
            145deg,
            color-mix(in srgb, var(--top-module-color, #ffffff) 24%, #ffffff),
            color-mix(in srgb, var(--top-module-color, #ffffff) 14%, #ffffff)
        );
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow:
        0 18px 46px rgba(42, 56, 68, 0.13),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

html[data-theme="light"][data-skin="standard"] .member-column {
    border: 1px solid rgba(37, 47, 56, 0.105);
    background:
        linear-gradient(
            145deg,
            color-mix(in srgb, var(--member-color, var(--accent)) var(--person-color-parent-mix, 10%), #ffffff),
            color-mix(in srgb, var(--member-color, var(--accent)) var(--person-color-parent-soft-mix, 7%), #ffffff)
        );
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow:
        0 28px 74px rgba(42, 56, 68, 0.15),
        0 10px 28px rgba(42, 56, 68, 0.075),
        inset 0 1px 0 rgba(255, 255, 255, 0.84);
}

html[data-theme="light"][data-skin="standard"] .person-modules {
    gap: var(--layout-module-gap);
}

html[data-theme="light"][data-skin="standard"] .person-module {
    border: 1px solid rgba(37, 47, 56, 0.085);
    background: #ffffff;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow:
        0 12px 30px rgba(42, 56, 68, 0.105),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

html[data-theme="light"][data-skin="standard"] .phase,
html[data-theme="light"][data-skin="standard"] .goal-item,
html[data-theme="light"][data-skin="standard"] .reflection-prompt,
html[data-theme="light"][data-skin="standard"] .reflection-support-prompt,
html[data-theme="light"][data-skin="standard"] .reflection-check-card,
html[data-theme="light"][data-skin="standard"] .family-question-card,
html[data-theme="light"][data-skin="standard"] .media-overview,
html[data-theme="light"][data-skin="standard"] .media-time-field {
    border-color: rgba(37, 47, 56, 0.075);
    background: #ffffff;
    box-shadow:
        0 8px 18px rgba(42, 56, 68, 0.07),
        inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

html[data-theme="light"][data-skin="standard"] .task-item {
    border-color: rgba(37, 47, 56, 0.065);
    background: #ffffff;
    box-shadow: none;
}

html[data-theme="light"][data-skin="standard"] .person-module.is-complete,
html[data-theme="light"][data-skin="standard"] .appointments-module.is-empty-complete {
    border-width: 2px;
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) var(--person-color-complete-mix, 68%), rgba(37, 47, 56, 0.14));
    background: color-mix(in srgb, var(--member-color, var(--accent)) var(--person-color-child-mix, 4%), #ffffff);
    box-shadow:
        inset 0 0 0 1px color-mix(in srgb, var(--member-color, var(--accent)) 18%, rgba(255, 255, 255, 0.5)),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

html[data-theme="light"][data-skin="standard"] .person-module.earns-family-point,
html[data-theme="light"][data-skin="standard"] .person-module.is-complete.earns-family-point,
html[data-theme="light"][data-skin="standard"] .appointments-module.is-empty-complete.earns-family-point {
    border-width: 2px;
    border-color: color-mix(in srgb, var(--member-color, var(--accent)) var(--person-color-complete-mix, 68%), rgba(37, 47, 56, 0.12));
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--member-color, var(--accent)) 24%, rgba(255, 255, 255, 0.56)),
        inset 0 0 0 1px color-mix(in srgb, var(--member-color, var(--accent)) 30%, rgba(255, 255, 255, 0.38)),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

/* Optional admin-uploaded background. It intentionally overrides the active skin background. */
html[data-custom-background="true"] body {
    background-color: #eef2f0;
    background-image: none !important;
}

html[data-theme="dark"][data-custom-background="true"] body {
    background-color: #121820;
    background-image: none !important;
}

html[data-custom-background="true"] body::before {
    display: block !important;
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    content: "";
    opacity: 1 !important;
    background-image:
        linear-gradient(135deg, rgba(246, 249, 248, 0.28), rgba(246, 249, 248, 0.04) 42%, rgba(230, 236, 236, 0.24)),
        var(--custom-background-landscape, var(--custom-background-image));
    background-position: center, center;
    background-size: cover, cover;
    background-repeat: no-repeat, no-repeat;
    background-attachment: fixed, fixed;
}

html[data-theme="dark"][data-custom-background="true"] body::before {
    background-image:
        linear-gradient(135deg, rgba(9, 13, 18, 0.58), rgba(9, 13, 18, 0.32) 44%, rgba(9, 13, 18, 0.62)),
        var(--custom-background-landscape, var(--custom-background-image));
}

@media (orientation: portrait) {
    html[data-custom-background="true"] body::before {
        background-image:
            linear-gradient(135deg, rgba(246, 249, 248, 0.28), rgba(246, 249, 248, 0.04) 42%, rgba(230, 236, 236, 0.24)),
            var(--custom-background-portrait, var(--custom-background-landscape, var(--custom-background-image)));
    }

    html[data-theme="dark"][data-custom-background="true"] body::before {
        background-image:
            linear-gradient(135deg, rgba(9, 13, 18, 0.58), rgba(9, 13, 18, 0.32) 44%, rgba(9, 13, 18, 0.62)),
            var(--custom-background-portrait, var(--custom-background-landscape, var(--custom-background-image)));
    }
}

html[data-custom-background="true"] body::after,
html[data-custom-background="true"] .app-shell::before {
    opacity: 0 !important;
    background: none !important;
}

html[data-custom-background="true"] .app-shell {
    position: relative;
    z-index: 1;
}

html[data-custom-background="true"] .church-scene-canvas {
    display: none !important;
}

.custom-background-form {
    grid-template-columns: minmax(150px, 0.65fr) minmax(260px, 1.35fr) auto;
    align-items: center;
}

.custom-background-toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: var(--layout-control-size);
    border: 1px solid rgba(37, 47, 56, 0.055);
    border-radius: 999px;
    padding: 0 12px;
    background: rgba(255, 255, 255, 0.58);
    color: var(--ink-soft);
    font-size: 0.82rem;
    font-weight: 520;
}

.custom-background-toggle input {
    width: 16px;
    height: 16px;
    accent-color: var(--accent);
}

.custom-background-picker {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 8px;
    min-width: 0;
    min-height: var(--layout-control-size);
    border: 1px solid rgba(37, 47, 56, 0.075);
    border-radius: 999px;
    padding: 3px 12px 3px 4px;
    background: rgba(255, 255, 255, 0.62);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.68);
}

.custom-background-file {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.custom-background-pick {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: calc(var(--layout-control-size) - 8px);
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.86);
    color: var(--ink-soft);
    font-size: 0.82rem;
    font-weight: 620;
    white-space: nowrap;
}

.custom-background-file-name {
    min-width: 0;
    overflow: hidden;
    color: var(--ink-soft);
    font-size: 0.82rem;
    font-weight: 560;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.custom-background-actions {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    min-width: max-content;
}

.custom-background-status {
    grid-column: 1 / -1;
    color: var(--muted);
    font-size: 0.76rem;
}

@media (max-width: 760px) {
    .custom-background-form {
        grid-template-columns: 1fr;
    }

    .custom-background-actions {
        justify-content: stretch;
        min-width: 0;
    }

    .custom-background-actions button {
        flex: 1 1 0;
    }
}

/* Mobile navigation polish. */
@media (max-width: 760px) {
    .top-dashboard > .topbar {
        grid-template-columns: 1fr;
        padding: 2px 4px 4px;
        border: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
    }

    .top-dashboard .topbar-brand {
        display: none;
    }

    .top-dashboard .topbar-actions,
    html[data-theme="light"][data-skin="standard"] .top-dashboard .topbar-actions,
    html[data-theme="dark"] .top-dashboard .topbar-actions,
    html[data-skin="kids"] .topbar-actions {
        display: flex;
        justify-content: center;
        gap: 14px;
        width: 100%;
        min-height: 38px;
        padding: 0 10px;
        border: 0;
        background: transparent;
        box-shadow: none;
        overflow: visible;
    }

    .top-dashboard .topbar-actions .icon-only,
    .top-dashboard .topbar-actions .icon-button,
    .top-dashboard .topbar-actions .logout-link {
        width: 34px;
        min-width: 34px;
        height: 34px;
        min-height: 34px;
    }

    .top-dashboard .daybar,
    html[data-theme="light"][data-skin="standard"] .top-dashboard .daybar {
        grid-template-columns: minmax(0, 1fr) 40px 66px 40px 40px;
        gap: 8px;
        align-items: center;
        padding: 10px 14px;
    }

    .top-dashboard .date-display-text,
    html[data-skin="kids"] .date-display-text {
        display: flex;
        align-items: center;
        min-height: 40px;
        padding: 0;
        line-height: 1.1;
    }

    .top-dashboard .daybar .icon-button,
    .top-dashboard .today-compact {
        width: 40px;
        min-width: 40px;
        height: 40px;
        min-height: 40px;
        padding: 0;
        line-height: 1;
    }

    .top-dashboard .today-compact {
        width: 66px;
        min-width: 66px;
        font-size: 0.95rem;
    }
}

/* Mobile card surfaces: keep soft rounded cards without clipped square corner artifacts. */
@media (max-width: 760px) {
    html[data-custom-background="true"] .app-shell,
    html[data-custom-background="true"][data-skin] .app-shell {
        background: transparent !important;
    }

    .top-dashboard {
        overflow: visible !important;
    }

    .top-dashboard > .global-deck,
    .global-deck {
        overflow: visible !important;
    }

    .top-dashboard .global-module-strip,
    .global-module-strip {
        width: 100%;
        padding: 8px 0 18px;
        overflow-x: auto;
        overflow-y: visible;
        scroll-padding-inline: 0;
    }

    .top-dashboard .global-card,
    .global-card,
    .family-upgrades-card,
    .member-column {
        background-clip: padding-box;
        isolation: isolate;
        overflow: hidden;
    }

    .top-dashboard .global-card,
    .global-card {
        flex-basis: 100%;
        max-width: 100%;
        border-radius: var(--layout-card-radius);
        box-shadow:
            0 22px 54px rgba(42, 56, 68, 0.12),
            0 8px 18px rgba(42, 56, 68, 0.055),
            inset 0 1px 0 rgba(255, 255, 255, 0.86);
    }

    .board {
        padding-top: 12px;
        overflow-y: visible;
    }

    .member-column {
        border-radius: var(--layout-card-radius);
        box-shadow:
            0 26px 64px rgba(42, 56, 68, 0.14),
            0 10px 24px rgba(42, 56, 68, 0.07),
            inset 0 1px 0 rgba(255, 255, 255, 0.84);
    }

    html[data-theme="dark"] .top-dashboard .global-card,
    html[data-theme="dark"] .global-card,
    html[data-theme="dark"] .member-column {
        box-shadow:
            0 24px 58px rgba(0, 0, 0, 0.3),
            inset 0 1px 0 rgba(255, 255, 255, 0.08);
    }
}

/* Mobile dashboard stack: each top module stands on its own, without an outer wrapper card. */
@media (max-width: 760px) {
    .top-dashboard,
    html[data-theme="dark"] .top-dashboard,
    html[data-skin] .top-dashboard {
        display: grid;
        gap: 14px;
        width: auto;
        max-width: none;
        margin: 0 10px 14px;
        border: 0 !important;
        border-radius: 0 !important;
        padding: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        overflow: visible !important;
    }

    html[data-skin="church"] .top-dashboard::before {
        display: none !important;
        content: none !important;
    }

    .top-dashboard > .topbar,
    html[data-theme="dark"] .top-dashboard > .topbar {
        display: grid;
        gap: 14px;
        width: 100%;
        max-width: none;
        margin: 0 !important;
        padding: 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        overflow: visible;
    }

    .top-dashboard .topbar-actions,
    html[data-theme="light"][data-skin="standard"] .top-dashboard .topbar-actions,
    html[data-theme="dark"] .top-dashboard .topbar-actions,
    html[data-skin="kids"] .topbar-actions {
        order: 1;
        margin: 0;
        padding-inline: 0;
    }

    .top-dashboard .notes-panel {
        position: static;
        z-index: auto;
        order: 2;
        width: 100%;
        margin: 0;
        padding: 0;
    }

    .top-dashboard .settings-panel {
        position: static;
        inset: auto;
        z-index: auto;
        order: 3;
        width: 100%;
        max-width: 100%;
        max-height: min(72dvh, 760px);
        margin: 0;
        overflow: auto;
    }

    .top-dashboard .daybar,
    html[data-theme="light"][data-skin="standard"] .top-dashboard .daybar {
        order: 1;
        width: 100%;
        margin: 0;
    }

    .top-dashboard > .global-deck,
    .top-dashboard .global-deck {
        display: grid;
        gap: 14px;
        width: 100%;
        max-width: none;
        margin: 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        padding: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        overflow: visible !important;
    }

    .top-dashboard .family-upgrades-card {
        width: 100%;
        margin: 0;
    }

    .top-dashboard .global-module-strip {
        width: 100%;
        margin: 0;
        gap: 14px;
        padding: 0;
    }

    .top-dashboard .global-card {
        flex: 0 0 100%;
        max-width: 100%;
        scroll-snap-align: center;
    }

    .board,
    .app-shell.is-swipe-layout .board {
        padding-top: 0;
    }

    .mobile-action-stack {
        display: grid;
        gap: 14px;
        width: auto;
        margin: 0 10px 16px;
    }

    .mobile-action-stack:empty {
        display: none;
    }

    .mobile-action-stack .notes-panel,
    .mobile-action-stack .settings-panel {
        position: static;
        inset: auto;
        z-index: auto;
        width: 100%;
        max-width: 100%;
        margin: 0;
    }

    .mobile-action-stack .notes-panel {
        padding: 0;
    }

    .mobile-action-stack .settings-panel {
        max-height: min(72dvh, 760px);
        overflow: auto;
    }

    .mobile-action-stack .topbar-actions,
    html[data-theme="light"][data-skin="standard"] .mobile-action-stack .topbar-actions,
    html[data-theme="dark"] .mobile-action-stack .topbar-actions,
    html[data-skin="kids"] .mobile-action-stack .topbar-actions {
        display: flex;
        justify-content: center;
        gap: 14px;
        width: 100%;
        min-height: 38px;
        margin: 0;
        border: 0;
        padding: 0;
        background: transparent;
        box-shadow: none;
        overflow: visible;
    }

    .mobile-action-stack .topbar-actions .icon-only,
    .mobile-action-stack .topbar-actions .icon-button,
    .mobile-action-stack .topbar-actions .logout-link {
        width: 34px;
        min-width: 34px;
        height: 34px;
        min-height: 34px;
    }
}

/* Android WebView fallback: newer Samsung WebView/GPU stacks can miscompose rounded isolated layers. */
@media (max-width: 760px) {
    html.android-webview .app-shell,
    html.android-webview .member-column,
    html.android-webview .person-module,
    html.android-webview .global-card,
    html.android-webview .family-upgrades-card {
        isolation: auto !important;
        will-change: auto !important;
        background-clip: border-box;
    }

    html.android-webview .member-column,
    html.android-webview .person-module {
        -webkit-backface-visibility: hidden;
        backface-visibility: hidden;
        -webkit-transform: translate3d(0, 0, 0) !important;
        transform: translate3d(0, 0, 0) !important;
    }

    html.android-webview .member-column {
        contain: layout paint !important;
        overflow: hidden !important;
    }

    html.android-webview .person-module {
        contain: paint !important;
        overflow: hidden !important;
    }

    html.android-webview .person-module {
        container-type: normal;
    }

    html.android-webview .phase,
    html.android-webview .task-list,
    html.android-webview .goal-item,
    html.android-webview .reflection-prompt,
    html.android-webview .reflection-support-prompt,
    html.android-webview .reflection-check-card,
    html.android-webview .family-question-card,
    html.android-webview .reflection-donation,
    html.android-webview .media-overview,
    html.android-webview .media-time-field {
        isolation: auto !important;
        contain: paint !important;
        overflow: hidden !important;
        -webkit-backface-visibility: hidden;
        backface-visibility: hidden;
        -webkit-transform: translate3d(0, 0, 0) !important;
        transform: translate3d(0, 0, 0) !important;
        will-change: auto !important;
        background-clip: border-box;
    }
}

/* Completed inner bento cards use the member color only when the whole module is done. */
.appointments-module.is-complete:not(.is-empty-complete) .phase,
.goals-module.is-complete .goal-item,
.reflection-module.is-complete .reflection-prompt,
.reflection-module.is-complete .reflection-support-prompt,
.family-question-module.is-complete .reflection-support-prompt,
.media-module.is-complete .media-overview {
    border-color: rgba(37, 47, 56, 0.105) !important;
    background:
        linear-gradient(
            145deg,
            color-mix(in srgb, var(--member-color, var(--accent)) var(--person-color-parent-mix, 10%), #ffffff),
            color-mix(in srgb, var(--member-color, var(--accent)) var(--person-color-parent-soft-mix, 7%), #ffffff)
        ) !important;
}

.appointments-module.is-complete:not(.is-empty-complete) .phase :is(.task-title, .task-title span, .task-marker, .edit-task-toggle, .phase-title h3, .school-presence, .school-presence span, .school-presence-display, .presence-defaults-toggle, .school-schedule-toggle),
.goals-module.is-complete .goal-item :is(.goal-main, .goal-main span, .goal-edit-toggle),
.reflection-module.is-complete :is(.reflection-prompt, .reflection-support-prompt, .reflection-prompt > span, .reflection-prompt small, .reflection-support-prompt small, .reflection-support-prompt p, .reflection-category, .reflection-category span, .reflection-card-actions button),
.family-question-module.is-complete .reflection-support-prompt :is(small, p, .reflection-category, .reflection-category span, .reflection-card-actions button),
.media-module.is-complete .media-overview :is(.media-summary, .media-chip) {
    color: rgba(255, 255, 255, 0.92) !important;
}

.appointments-module.is-complete:not(.is-empty-complete) .phase :is(.task-state, .edit-task-toggle),
.goals-module.is-complete .goal-item :is(.goal-status-toggle, .goal-edit-toggle),
.reflection-module.is-complete :is(.reflection-item-toggle, .reflection-write-toggle),
.family-question-module.is-complete :is(.reflection-item-toggle, .reflection-write-toggle) {
    border-color: rgba(255, 255, 255, 0.42) !important;
    background: rgba(255, 255, 255, 0.18) !important;
    color: #ffffff !important;
}

.appointments-module.is-complete:not(.is-empty-complete) .phase .edit-task-toggle,
.goals-module.is-complete .goal-item .goal-edit-toggle,
.reflection-module.is-complete .reflection-write-toggle,
.family-question-module.is-complete .reflection-write-toggle {
    border-color: transparent !important;
    background: transparent !important;
    box-shadow: none !important;
    color: rgba(255, 255, 255, 0.88) !important;
}

html[data-theme="dark"] .appointments-module.is-complete:not(.is-empty-complete) .phase,
html[data-theme="dark"] .goals-module.is-complete .goal-item,
html[data-theme="dark"] .reflection-module.is-complete .reflection-prompt,
html[data-theme="dark"] .reflection-module.is-complete .reflection-support-prompt,
html[data-theme="dark"] .family-question-module.is-complete .reflection-support-prompt,
html[data-theme="dark"] .media-module.is-complete .media-overview {
    border-color: var(--stroke) !important;
    background: color-mix(in srgb, var(--member-color, var(--accent)) 9%, rgba(18, 24, 30, 0.9)) !important;
}

.appointments-module .phase .task-item.recurring-rate-soft:not(.done):not(.skipped) :is(.task-title, .task-title-text, .task-marker),
.appointments-module .phase .task-item[data-recurring-completion-level="soft"]:not(.done):not(.skipped) :is(.task-title, .task-title-text, .task-marker) {
    color: color-mix(in srgb, var(--danger) 74%, var(--ink-soft)) !important;
}

.appointments-module .phase .task-item.recurring-rate-strong:not(.done):not(.skipped) :is(.task-title, .task-title-text, .task-marker),
.appointments-module .phase .task-item.recurring-rate-critical:not(.done):not(.skipped) :is(.task-title, .task-title-text, .task-marker),
.appointments-module .phase .task-item[data-recurring-completion-level="strong"]:not(.done):not(.skipped) :is(.task-title, .task-title-text, .task-marker),
.appointments-module .phase .task-item[data-recurring-completion-level="critical"]:not(.done):not(.skipped) :is(.task-title, .task-title-text, .task-marker) {
    color: var(--danger) !important;
}

.appointments-module .phase .task-item.recurring-rate-strong:not(.done):not(.skipped) .task-title,
.appointments-module .phase .task-item.recurring-rate-critical:not(.done):not(.skipped) .task-title,
.appointments-module .phase .task-item[data-recurring-completion-level="strong"]:not(.done):not(.skipped) .task-title,
.appointments-module .phase .task-item[data-recurring-completion-level="critical"]:not(.done):not(.skipped) .task-title {
    font-weight: 650;
}

.appointments-module .phase .task-item.recurring-rate-critical:not(.done):not(.skipped) .task-title-text,
.appointments-module .phase .task-item[data-recurring-completion-level="critical"]:not(.done):not(.skipped) .task-title-text {
    animation: recurringCompletionPulse 1.9s ease-in-out infinite;
}

.person-module.module-rate-soft .module-header :is(h3, button, span),
.person-module.module-rate-soft .media-title-toggle,
.person-module.module-rate-soft .goal-title-toggle,
.person-module.module-rate-soft .appointment-title-toggle {
    color: color-mix(in srgb, var(--danger) 74%, var(--ink-soft)) !important;
}

.person-module.module-rate-strong .module-header :is(h3, button, span),
.person-module.module-rate-critical .module-header :is(h3, button, span),
.person-module.module-rate-strong .media-title-toggle,
.person-module.module-rate-critical .media-title-toggle,
.person-module.module-rate-strong .goal-title-toggle,
.person-module.module-rate-critical .goal-title-toggle,
.person-module.module-rate-strong .appointment-title-toggle,
.person-module.module-rate-critical .appointment-title-toggle {
    color: var(--danger) !important;
    font-weight: 720 !important;
}

.person-module.module-rate-critical .module-header :is(h3, button, span) {
    animation: recurringCompletionPulse 1.9s ease-in-out infinite;
}

.person-module.is-complete:is(.module-rate-soft, .module-rate-strong, .module-rate-critical) .module-header :is(h3, button, span),
.person-module.is-complete:is(.module-rate-soft, .module-rate-strong, .module-rate-critical) :is(.media-title-toggle, .goal-title-toggle, .appointment-title-toggle) {
    color: var(--muted) !important;
    font-weight: inherit !important;
    animation: none !important;
}

@keyframes recurringCompletionPulse {
    0%,
    100% {
        opacity: 1;
        text-shadow: none;
    }

    50% {
        opacity: 0.72;
        text-shadow: 0 0 10px color-mix(in srgb, var(--danger) 32%, transparent);
    }
}

@media (prefers-reduced-motion: reduce) {
    .appointments-module .phase .task-item.recurring-rate-critical:not(.done):not(.skipped) .task-title-text,
    .appointments-module .phase .task-item[data-recurring-completion-level="critical"]:not(.done):not(.skipped) .task-title-text,
    .task-completion-warning-critical,
    .person-module.module-rate-critical .module-header :is(h3, button, span) {
        animation: none;
    }
}

.topbar-actions .notes-toggle.icon-only,
.topbar-actions .home-guide-toggle.icon-only.is-admin-role {
    display: inline-grid;
    opacity: 1;
    visibility: visible;
}

.topbar-actions .notes-toggle.icon-only[aria-expanded="false"],
.topbar-actions .home-guide-toggle.icon-only.is-admin-role[aria-expanded="false"] {
    background: transparent;
    color: var(--muted);
    box-shadow: none;
    filter: none;
}

.notes-toggle.icon-only[aria-expanded="true"],
.notes-toggle.icon-only.is-panel-open,
.notes-toggle.icon-only[aria-expanded="true"]:hover,
.home-guide-toggle.icon-only.is-admin-role[aria-expanded="true"],
.home-guide-toggle.icon-only.is-admin-role.is-panel-open,
.home-guide-toggle.icon-only.is-admin-role[aria-expanded="true"]:hover {
    border-radius: 999px;
    background: color-mix(in srgb, var(--accent) 16%, rgba(255, 255, 255, 0.56));
    color: color-mix(in srgb, var(--accent) 76%, var(--ink));
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--accent) 24%, transparent),
        0 10px 24px rgba(42, 56, 68, 0.08);
}

html[data-theme="dark"] .notes-toggle.icon-only[aria-expanded="true"],
html[data-theme="dark"] .notes-toggle.icon-only.is-panel-open,
html[data-theme="dark"] .notes-toggle.icon-only[aria-expanded="true"]:hover,
html[data-theme="dark"] .home-guide-toggle.icon-only.is-admin-role[aria-expanded="true"],
html[data-theme="dark"] .home-guide-toggle.icon-only.is-admin-role.is-panel-open,
html[data-theme="dark"] .home-guide-toggle.icon-only.is-admin-role[aria-expanded="true"]:hover {
    background: color-mix(in srgb, var(--accent) 26%, rgba(255, 255, 255, 0.07));
    color: color-mix(in srgb, var(--accent) 68%, #ffffff);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--accent) 32%, rgba(255, 255, 255, 0.1)),
        0 10px 24px rgba(0, 0, 0, 0.18);
}

@media (hover: none) and (pointer: coarse) {
    .topbar-actions .notes-toggle.icon-only:hover,
    .topbar-actions .home-guide-toggle.icon-only.is-admin-role:hover {
        background: transparent;
        color: var(--muted);
        box-shadow: none;
        filter: none;
    }

    .topbar-actions .notes-toggle.icon-only[aria-expanded="true"]:hover,
    .topbar-actions .notes-toggle.icon-only.is-panel-open:hover,
    .topbar-actions .home-guide-toggle.icon-only.is-admin-role[aria-expanded="true"]:hover,
    .topbar-actions .home-guide-toggle.icon-only.is-admin-role.is-panel-open:hover {
        background: color-mix(in srgb, var(--accent) 16%, rgba(255, 255, 255, 0.56));
        color: color-mix(in srgb, var(--accent) 76%, var(--ink));
        box-shadow:
            0 0 0 1px color-mix(in srgb, var(--accent) 24%, transparent),
            0 10px 24px rgba(42, 56, 68, 0.08);
    }

    html[data-theme="dark"] .topbar-actions .notes-toggle.icon-only[aria-expanded="true"]:hover,
    html[data-theme="dark"] .topbar-actions .notes-toggle.icon-only.is-panel-open:hover,
    html[data-theme="dark"] .topbar-actions .home-guide-toggle.icon-only.is-admin-role[aria-expanded="true"]:hover,
    html[data-theme="dark"] .topbar-actions .home-guide-toggle.icon-only.is-admin-role.is-panel-open:hover {
        background: color-mix(in srgb, var(--accent) 26%, rgba(255, 255, 255, 0.07));
        color: color-mix(in srgb, var(--accent) 68%, #ffffff);
        box-shadow:
            0 0 0 1px color-mix(in srgb, var(--accent) 32%, rgba(255, 255, 255, 0.1)),
            0 10px 24px rgba(0, 0, 0, 0.18);
    }
}
