:root {
    --primary: #6750a4;
    --primary-hover: #5a4394;
    --primary-active: #4f378b;
    --on-primary: #ffffff;

    --secondary-bg: #f4efff;
    --secondary-hover: #eaddff;
    --secondary-active: #d0bcff;
    --secondary-text: #4f378b;
    --secondary-border: #79747e;

    --tertiary-bg: #fff8fb;
    --tertiary-hover: #ffd8e4;
    --tertiary-active: #efb8c8;
    --tertiary-text: #633b48;
    --tertiary-border: #79747e;

    --background: #fffbfe;
    --surface: #ffffff;
    --surface-alt: #f7f2fa;

    --text: #1d1b20;
    --text-muted: #49454f;

    --border: #cac4d0;

    --success: #386a20;
    --warning: #7d5800;
    --danger: #ba1a1a;
    --splash-bg: #6750a4;

    --radius-sm: 10px;
    --radius-md: 16px;
    --radius-lg: 24px;
    --radius-pill: 999px;

    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.06);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);

    /* compatibility aliases for the existing app */
    --bg: var(--background);
    --surface-low: var(--surface-alt);
    --surface-high: #e8def8;
    --muted: var(--text-muted);
    --primary-strong: var(--primary-active);
    --secondary: var(--secondary-text);
    --outline: var(--secondary-border);
    --error: var(--danger);
    --shadow: var(--shadow-md);
    --radius-card: var(--radius-lg);
    --radius-hero: 40px;
    --transition: 300ms cubic-bezier(0.2, 0, 0, 1);
}

* {
    box-sizing: border-box;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

*::-webkit-scrollbar {
    width: 0;
    height: 0;
    display: none;
}

html,
body {
    margin: 0;
    padding: 0;
    min-height: 100%;
}

[hidden] {
    display: none !important;
}

body {
    font-family: "Varela Round", Arial, sans-serif;
    background: var(--primary);
    color: var(--text);
    line-height: 1.5;
    overflow-x: hidden;
}

body.route-dashboard::before {
    content: "";
    position: fixed;
    inset: 0;
    background:
        linear-gradient(rgba(103, 80, 164, 0.18), rgba(103, 80, 164, 0.18)),
        url("../home-bg-q80.jpg") center center / cover no-repeat;
    filter: blur(24px);
    transform: scale(1.08);
    transform-origin: center;
    z-index: -2;
    pointer-events: none;
}

body.route-onboarding {
    overflow: hidden;
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input,
textarea,
select {
    font: inherit;
}

body.is-loading-prayer {
    overflow: hidden;
}

.loading-screen {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: grid;
    place-items: center;
    background: #6750a4;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 180ms ease, visibility 180ms ease;
    will-change: opacity;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
}

.loading-screen.is-visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.loading-screen__content {
    display: grid;
    justify-items: center;
    gap: 16px;
    text-align: center;
    color: #d0bcff;
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.loading-screen__dots {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 16px;
}

.loading-screen__dots span {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: #d0bcff;
    opacity: .2;
    animation: loading-dot 1.2s ease-in-out infinite;
    will-change: opacity, transform;
    transform: translateZ(0);
}

.loading-screen__dots span:nth-child(2) {
    animation-delay: .2s;
}

.loading-screen__dots span:nth-child(3) {
    animation-delay: .4s;
}

.notification-prompt {
    position: fixed;
    inset: 0;
    z-index: 9998;
    display: grid;
    place-items: center;
    padding: 24px;
    background: rgba(103, 80, 164, 0.96);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 220ms ease, visibility 220ms ease;
}

.notification-prompt.is-visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.notification-prompt__content {
    width: min(100%, 420px);
    display: grid;
    gap: 16px;
    justify-items: center;
    text-align: center;
    color: #ffffff;
}

.notification-prompt__content h2 {
    margin: 0;
    font-size: clamp(2rem, 8vw, 2.5rem);
    line-height: 1.15;
}

.notification-prompt__content .muted {
    color: rgba(255, 255, 255, 0.88);
    margin: 0;
}

.notification-prompt__eyebrow {
    margin: 0;
    color: #d0bcff;
    font-size: 0.86rem;
    font-weight: 600;
}

.notification-prompt__button {
    width: 100%;
    min-height: 56px;
    border-radius: 18px;
}

.notification-prompt__skip {
    appearance: none;
    border: 0;
    background: transparent;
    color: rgba(255, 255, 255, 0.85);
    padding: 8px 12px;
    cursor: pointer;
}

.splash-page {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
    padding: 24px;
    background: var(--splash-bg);
    z-index: 20;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 260ms ease, visibility 260ms ease;
    will-change: opacity;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
}

.splash-page.is-visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.splash-page.is-exiting {
    opacity: 0;
}

.splash-page.is-exiting .splash-page__logo,
.splash-page.is-exiting .splash-page__name,
.splash-page.is-exiting .splash-page__tagline {
    animation: none;
    opacity: 0;
    transform: translate3d(0, -10px, 0) scale(.98);
    transition: opacity 300ms ease, transform 300ms ease;
}

.splash-page .ambient {
    position: absolute;
    z-index: 0;
}

.splash-page__inner {
    position: relative;
    z-index: 1;
    display: grid;
    justify-items: center;
    gap: 14px;
    text-align: center;
}

.splash-page__logo {
    width: min(82vw, 320px);
    max-width: 320px;
    height: auto;
    display: block;
    opacity: 0;
    transform: translate3d(0, 12px, 0) scale(.98);
    will-change: opacity, transform;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.splash-page.is-visible .splash-page__logo {
    animation: splash-fade-in 2.2s ease forwards;
}

.splash-page__name {
    margin: 0;
    color: #f4efff;
    font-family: "Varela Round", Arial, sans-serif;
    font-size: clamp(2.25rem, 9vw, 4rem);
    line-height: 1;
    letter-spacing: 0;
    opacity: 0;
    transform: translate3d(0, 12px, 0) scale(.98);
    will-change: opacity, transform;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.splash-page.is-visible .splash-page__name {
    animation: splash-fade-in 2.2s ease .18s forwards;
}

.splash-page__tagline {
    margin: 0;
    color: rgba(244, 239, 255, 0.92);
    font-size: clamp(1rem, 3.8vw, 1.3rem);
    line-height: 1.35;
    letter-spacing: 0;
    opacity: 0;
    transform: translate3d(0, 12px, 0) scale(.98);
    will-change: opacity, transform;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.splash-page.is-visible .splash-page__tagline {
    animation: splash-fade-in 2.2s ease .32s forwards;
}

.ios-install-gate {
    position: fixed;
    inset: 0;
    z-index: 30;
    display: grid;
    place-items: center;
    padding: 24px 20px 32px;
    background: #6750a4;
    color: #ffffff;
}

.ios-install-gate__inner {
    width: min(100%, 420px);
    display: grid;
    justify-items: center;
    gap: 18px;
    text-align: center;
}

.ios-install-gate__brand {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    text-align: left;
}

.ios-install-gate__logo {
    width: min(28vw, 104px);
    height: auto;
    display: block;
}

.ios-install-gate__copy {
    display: grid;
    gap: 8px;
}

.ios-install-gate__copy h1 {
    margin: 0;
    font-size: clamp(2rem, 8vw, 2.6rem);
    line-height: 1.1;
    color: #ffffff;
}

.ios-install-gate__copy h2 {
    margin: 0;
    font-size: 1rem;
    line-height: 1.3;
    color: #f4efff;
}

.ios-install-gate__copy p,
.ios-install-gate__note {
    margin: 0;
    color: #f4efff;
}

.ios-install-gate__media {
    width: min(100%, 220px);
    padding: 8px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.08);
    box-shadow: 0 16px 36px rgba(0, 0, 0, 0.18);
}

.ios-install-gate__media video,
.ios-install-gate__media img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 22px;
}

@keyframes splash-fade-in {
    0% {
        opacity: 0;
        transform: translate3d(0, 12px, 0) scale(.98);
    }

    100% {
        opacity: 1;
        transform: translate3d(0, 0, 0) scale(1);
    }
}

@keyframes loading-dot {

    0%,
    20% {
        opacity: .18;
        transform: translateY(0);
    }

    35% {
        opacity: 1;
        transform: translateY(-2px);
    }

    55%,
    100% {
        opacity: .18;
        transform: translateY(0);
    }
}

.app-shell {
    min-height: 100vh;
    position: relative;
    overflow-x: hidden;
    background: transparent;
    color: var(--text);
    opacity: 0;
    transition: opacity 220ms ease;
}

body.is-page-ready .app-shell {
    opacity: 1;
}

body.is-page-leaving .app-shell {
    opacity: 0;
    pointer-events: none;
}

.app-shell--dashboard {
    background:
        linear-gradient(rgba(29, 20, 44, 0.18), rgba(29, 20, 44, 0.18)),
        url("../home-bg-q80.jpg") center center / cover no-repeat;
    border-radius: 0;
}

.ambient {
    position: fixed;
    border-radius: 9999px;
    filter: blur(72px);
    opacity: .22;
    pointer-events: none;
    z-index: 0;
}

.ambient-1 {
    width: 280px;
    height: 280px;
    background: #d0bcff;
    top: -80px;
    right: -40px;
}

.ambient-2 {
    width: 260px;
    height: 260px;
    background: #b7e0f7;
    bottom: 16%;
    left: -70px;
}

.ambient-3 {
    width: 220px;
    height: 220px;
    background: #ffd8e4;
    top: 38%;
    right: 12%;
}

.topbar,
.page {
    position: relative;
    z-index: 1;
}

.topbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: calc(18px + env(safe-area-inset-top, 0px)) 20px 18px;
    background: linear-gradient(to bottom, rgba(0,0,0,0.5), rgba(0,0,0,0));
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    color: #f4efff;
    font-size: 20px;
    line-height: 1.2;
    font-weight: 600;
    letter-spacing: 0;
}

.brand__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    color: currentColor;
    flex: 0 0 auto;
}

.brand__icon img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.brand__name {
    display: inline-block;
}

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

.nav a {
    padding: 10px 16px;
    border-radius: 9999px;
    color: var(--primary);
    transition: background var(--transition), transform 200ms ease;
}

.nav a:hover,
.nav a:focus-visible {
    background: rgba(103, 80, 164, .10);
}

.nav a:active {
    transform: scale(.95);
}

.bottom-nav {
    position: fixed;
    left: 12px;
    right: 12px;
    bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    z-index: 10;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    padding: 10px;
    background: rgba(243, 237, 247, .95);
    -webkit-backdrop-filter: blur(18px);
    backdrop-filter: blur(18px);
    border: 1px solid rgba(121, 116, 126, .12);
    border-radius: 30px;
    box-shadow: 0 18px 36px rgba(103, 80, 164, 0.18);
}

.payment-qr {
    display: block;
    width: min(100%, 340px);
    margin: 0 auto;
    border-radius: 12px;
    background: #ffffff;
    box-shadow: var(--shadow-sm);
}

.payment-qr-grid {
    display: grid;
    gap: 16px;
}

.payment-qr-card {
    gap: 14px;
}

.payment-qr-card h3 {
    margin-bottom: 4px;
}

.payment-proof-preview {
    display: block;
    width: 100%;
    max-width: 420px;
    margin: 0 auto;
    border-radius: 12px;
    background: #ffffff;
    box-shadow: var(--shadow-sm);
}

.subscription-payment-card {
    gap: 20px;
}

.subscription-plan-grid {
    display: grid;
    gap: 12px;
}

.subscription-plan-card {
    width: 100%;
    padding: 18px;
    border: 0;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.8);
    color: var(--text);
    box-shadow: var(--shadow-sm);
    text-align: left;
    cursor: pointer;
}

.subscription-plan-card strong {
    display: block;
    font-size: 1.05rem;
}

.subscription-plan-card .muted {
    margin: 6px 0 0;
}

.subscription-plan-card--static {
    cursor: default;
}

.benefit-list {
    margin: 0;
    padding-left: 20px;
    display: grid;
    gap: 10px;
}

.benefit-list--compact {
    margin-top: 12px;
    gap: 8px;
    padding-left: 18px;
}

.benefit-list li {
    color: var(--text);
}

.bottom-nav__item {
    min-height: 64px;
    border-radius: 24px;
    display: grid;
    justify-items: center;
    align-content: center;
    gap: 6px;
    color: #000;
    font-size: .78rem;
    transition: background var(--transition), color var(--transition), transform 200ms ease;
}

.bottom-nav__item:hover,
.bottom-nav__item:focus-visible {
    background: rgba(103, 80, 164, .08);
    color: var(--primary);
}

.bottom-nav__item.is-active {
    background: rgba(103, 80, 164, .12);
    color: var(--primary);
    font-weight: 600;
}

.nav-icon,
.btn svg {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.nav-icon svg,
.btn svg {
    width: 20px;
    height: 20px;
    stroke: currentColor;
    stroke-width: 2;
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.page {
    width: min(1120px, calc(100% - 24px));
    margin: 0 auto;
    padding: 20px 0 105px;
}

.hero,
.card,
.stat-card,
.summary-card {
    background: var(--secondary-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-card);
    box-shadow: var(--shadow-sm), 0 6px 18px rgba(29, 27, 32, 0.05);
}

.surface-alt {
    background: var(--surface-alt);
}

.hero {
    display: grid;
    gap: 20px;
    padding: 28px;
    border-radius: var(--radius-hero);
    margin-bottom: 20px;
}

.hero.compact {
    grid-template-columns: 1fr;
}

.hero.compact {
    margin-bottom: 0;
    background: var(--primary);
    color: #ffffff;
}

.hero.compact .eyebrow,
.hero.compact .hero-copy p,
.hero.compact .muted {
    color: #ffffff;
}

.auth-hero {
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
    gap: 18px;
    background: transparent;
    border: 0;
    box-shadow: none;
    padding: 12px 0 0;
}

.auth-hero__copy {
    color: #fff;
    max-width: 36rem;
}

.auth-hero__copy .eyebrow,
.auth-hero__copy p {
    color: rgba(255,255,255,0.88);
}

.auth-stack {
    width: min(100%, 560px);
    margin: 0 auto;
    padding-top: 12px;
    gap: 16px;
}

.auth-stack__copy {
    color: #fff;
}

.auth-stack__copy .eyebrow,
.auth-stack__copy p {
    color: rgba(255,255,255,0.88);
}

.auth-stack__copy h1 {
    margin: 0 0 8px;
    font-size: clamp(2rem, 8vw, 2.8rem);
    line-height: 1.12;
}

.auth-stack__card {
    padding: 20px;
}

.login-form,
.auth-stack__copy,
.auth-stack__card {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity 420ms ease, transform 420ms ease;
}

body.is-page-ready .login-form,
body.is-page-ready .auth-stack__copy,
body.is-page-ready .auth-stack__card {
    opacity: 1;
    transform: translateY(0);
}

.route-login .login-form {
    animation: login-form-fade-in 420ms ease 120ms forwards;
}

.auth-stack__card {
    transition-delay: 120ms;
}

@keyframes login-form-fade-in {
    from {
        opacity: 0;
        transform: translateY(18px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.auth-card {
    width: 100%;
    max-width: 100%;
}

.auth-card--transparent {
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.18);
    box-shadow: none;
    backdrop-filter: blur(12px);
}

.auth-card--transparent:hover {
    transform: none;
    box-shadow: none;
}

.auth-card--transparent label {
    color: #fff;
}

.auth-card--transparent .field {
    background: rgba(255,255,255,0.9);
}

@media (min-width: 980px) {
    .auth-hero--signup {
        grid-template-columns: minmax(0, 1.15fr) minmax(0, 420px);
        gap: 40px;
        padding-top: 24px;
    }
}

@media (max-width: 419px) {
    .auth-stack {
        padding-top: 4px;
        gap: 14px;
    }

    .auth-stack__card {
        padding: 16px;
    }
}

.hero-copy h1,
.page-header h1,
.card h1 {
    margin: 0 0 8px;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1.15;
}

.hero-copy p,
.muted {
    color: var(--muted);
}

.hero-copy a {
    color: var(--secondary-active);
    font-size: calc(1em - 4px);
    text-decoration: underline;
}

.home-focus {
    min-height: calc(100svh - 185px);
    display: grid;
    align-items: start;
    justify-items: center;
    padding: 24px 0 24px;
    position: relative;
}

.home-focus__clouds {
    position: fixed;
    inset: -4% -18%;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;
}

.home-focus__cloud {
    position: absolute;
    display: block;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.18);
    filter: blur(24px);
    box-shadow:
        48px 10px 0 8px rgba(255, 255, 255, 0.16),
        108px -8px 0 0 rgba(255, 255, 255, 0.14),
        154px 8px 0 10px rgba(255, 255, 255, 0.12);
    animation: home-cloud-drift linear infinite;
    will-change: transform;
}

.home-focus__cloud--1 {
    top: 12%;
    left: -26%;
    width: 108px;
    height: 34px;
    opacity: 0.95;
    animation-duration: 34s;
}

.home-focus__cloud--2 {
    top: 28%;
    left: -34%;
    width: 132px;
    height: 40px;
    opacity: 0.7;
    animation-duration: 42s;
    animation-delay: -10s;
}

.home-focus__cloud--3 {
    top: 62%;
    left: -22%;
    width: 96px;
    height: 30px;
    opacity: 0.6;
    animation-duration: 30s;
    animation-delay: -16s;
}

.home-focus__cloud--4 {
    top: 76%;
    left: -38%;
    width: 144px;
    height: 42px;
    opacity: 0.56;
    animation-duration: 48s;
    animation-delay: -5s;
}

.home-focus__panel {
    width: min(100%, 500px);
    display: grid;
    justify-items: center;
    gap: 26px;
    text-align: center;
    color: #ffffff;
    position: relative;
    z-index: 1;
    padding: 16px 22px;
}

.home-focus__logo {
    width: min(52vw, 210px);
    aspect-ratio: 1;
    display: grid;
    place-items: center;
}

.home-focus__logo img {
    width: 100%;
    height: auto;
    display: block;
    filter: drop-shadow(0 12px 30px rgba(0, 0, 0, 0.18));
}

.home-focus__copy {
    display: grid;
    gap: 0;
    align-self: start;
    margin-top: 0;
}

.home-focus__copy h1 {
    margin: 0;
    font-size: 40px;
    line-height: 1.03;
    letter-spacing: 0;
    text-shadow: 0 0 10px rgba(0,0,0,0.15);
}

.home-focus__copy p {
    margin: 0;
    color: rgba(255, 255, 255, 0.88);
}

.home-focus__greeting {
    color: var(#fff) !important;
    font-size: 1rem;
}

.home-focus__cta {
    width: 100%;
    min-height: 76px;
    justify-content: center;
    border-radius: 28px;
    padding: 22px 24px;
    font-size: 1.22rem;
    line-height: 1.18;
    background: #ffffff;
    color: var(--primary);
    box-shadow: 0 20px 44px rgba(37, 21, 84, 0.34), 0 0 0 6px rgba(255, 255, 255, 0.18);
}

.home-focus__cta:hover,
.home-focus__cta:focus-visible {
    background: #f4efff;
    color: var(--primary-active);
}

.home-focus__cta:active {
    background: #eaddff;
}

.home-focus__reminder {
    margin: 0;
    color: rgba(255, 255, 255, 1);
    font-size: 0.82rem;
}

.home-focus__reminder-link {
    margin-left: 6px;
    color: var(--secondary-active);
    font-size: 0.72rem;
    text-decoration: underline;
}

@keyframes home-cloud-drift {
    0% {
        transform: translate3d(0, 0, 0);
    }

    100% {
        transform: translate3d(calc(100vw + 420px), 0, 0);
    }
}

.eyebrow {
    display: inline-block;
    margin-bottom: 10px;
    color: var(--primary);
    font-size: .82rem;
    font-weight: 600;
    letter-spacing: .01em;
}

.single-column {
    display: grid;
    gap: 20px;
}

.single-column.narrow {
    width: min(680px, 100%);
    margin: 0 auto;
}

.page-header {
    margin: 8px 0 4px;
}

.page-header-light h1 {
    color: #ffffff;
}

.card {
    padding: 24px;
    transition: transform var(--transition), box-shadow var(--transition);
}

.card:hover {
    transform: scale(1.01);
    box-shadow: var(--shadow-md);
}

.form-stack {
    display: grid;
    gap: 16px;
}

.section-block {
    display: grid;
    gap: 12px;
}

.section-block-tight {
    gap: 6px;
}

.section-block h2 {
    margin: 0;
    line-height: 1.2;
}

.section-block p {
    margin: 0;
}

.prayer-body {
    gap: 2px;
}

.two-up {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.two-up>label {
    min-width: 0;
}

.field {
    width: 100%;
    margin-top: 8px;
    border: 0;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.5);
    color: var(--text);
    min-height: 56px;
    padding: 14px 16px;
    outline: none;
    box-shadow: var(--shadow-sm), 0 6px 16px rgba(29, 27, 32, 0.06);
    transition: border-color 200ms ease, box-shadow 200ms ease;
}

.field:focus {
    border-bottom-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(103, 80, 164, .16);
}

.field[type="time"] {
    max-width: 100%;
    min-width: 0;
    display: block;
    box-sizing: border-box;
}

.field-area {
    min-height: 120px;
    resize: vertical;
}

.btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    min-height: 44px;
    padding: 0 20px;
    border: 0;
    border-radius: var(--radius-pill);
    cursor: pointer;
    font-size: 15px;
    font-weight: 600;
    transition: transform 200ms ease, background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease, opacity 0.15s ease, box-shadow var(--transition);
}

.btn:active {
    transform: scale(.95);
}

.btn-primary {
    background: var(--primary);
    color: var(--on-primary);
}

.btn-primary:hover,
.btn-primary:focus-visible {
    background: var(--primary-hover);
}

.btn-primary:active {
    background: var(--primary-active);
}

.btn-tonal {
    background: rgba(255, 255, 255, 0.5);
    color: var(--secondary-text);
}

.btn-tonal:hover,
.btn-tonal:focus-visible {
    background: var(--surface-alt);
    box-shadow: inset 0 0 0 1px var(--primary);
}

.btn-tonal:active {
    background: var(--secondary-hover);
}

.btn-ghost {
    background: var(--tertiary-bg);
    color: var(--tertiary-text);
}

.btn-ghost:hover,
.btn-ghost:focus-visible {
    background: var(--tertiary-hover);
}

.btn-ghost:active {
    background: var(--tertiary-active);
}

.btn:disabled {
    background: #e6e0e9;
    color: #938f99;
    cursor: not-allowed;
    opacity: 0.7;
}

.flash-stack {
    position: fixed;
    top: max(12px, calc(env(safe-area-inset-top, 0px) + 8px));
    left: 0;
    right: 0;
    z-index: 70;
    display: grid;
    gap: 10px;
    justify-items: center;
    padding: 0 16px;
    pointer-events: none;
}

.flash {
    width: min(100%, 420px);
    padding: 14px 18px;
    border-radius: 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
    border: 1px solid rgba(255, 255, 255, 0.16);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    transform: translateY(-18px) scale(0.98);
    opacity: 0;
    transition: transform 240ms ease, opacity 240ms ease;
    pointer-events: auto;
    background: rgba(0, 0, 0, 0.5);
    background-color: rgba(0, 0, 0, 0.5);
    color: #fff;
}

.flash__icon {
    flex: 0 0 auto;
    font-size: 1rem;
    line-height: 1;
}

.flash__text {
    min-width: 0;
    color: inherit;
}

.flash.is-visible {
    transform: translateY(0) scale(1);
    opacity: 1;
}

.flash.is-hiding {
    transform: translateY(-18px) scale(0.98);
    opacity: 0;
}

.flash-success,
.flash.flash-success {
    background: rgba(0, 0, 0, 0.5);
    background-color: rgba(0, 0, 0, 0.5);
    color: #fff;
    opacity: 1;
}

.flash-error,
.flash.flash-error {
    background: rgba(0, 0, 0, 0.5);
    background-color: rgba(0, 0, 0, 0.5);
    color: #fff;
}

.chip-grid,
.stats-grid,
.list-stack {
    display: grid;
    gap: 12px;
}

.chip-grid {
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.chip {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 16px;
    background: rgba(255, 255, 255, .42);
    border-radius: 20px;
}

.segmented {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.segment,
.radio-row,
.toggle {
    display: flex;
    align-items: center;
    gap: 10px;
}

.segment {
    padding: 10px 16px;
    background: rgba(255, 255, 255, .46);
    border-radius: 9999px;
}

.action-panel,
.pricing-card {
    display: grid;
    gap: 16px;
}

.action-panel {
    background: var(--secondary-bg);
}

.checkin-card {
    gap: 22px;
    background: var(--surface);
}

.prayer-chat {
    background: rgba(255, 255, 255, 0.4);
    position: relative;
    padding-top: 26px;
    padding-bottom: 112px;
}

.prayer-chat--composing {
    margin-bottom: 78px;
}

.checkin-layout {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
}

.checkin-layout .prayer-chat {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
}

.page-audio-unlock {
    position: fixed;
    inset: 0;
    z-index: 80;
    display: grid;
    place-items: center;
    padding: 24px;
    background: rgba(20, 13, 31, 0.82);
    backdrop-filter: blur(10px);
}

.page-audio-unlock[hidden] {
    display: none !important;
}

.page-audio-unlock__content {
    width: min(100%, 360px);
    display: grid;
    gap: 16px;
    text-align: center;
    color: #fff;
}

.page-audio-unlock__content [data-page-audio-loading] {
    font-size: clamp(1.2rem, 5vw, 1.5rem);
    font-weight: 600;
}

.page-audio-unlock__content h2,
.page-audio-unlock__content p {
    margin: 0;
}

[data-page-audio-loading][hidden],
[data-page-audio-unlock-button][hidden] {
    display: none !important;
}

.page-audio-unlock__content [data-page-audio-unlock-button] {
    width: min(100%, 300px);
    min-height: 60px;
    margin: 0 auto;
    padding: 0 28px;
    font-size: clamp(1.1rem, 4.8vw, 1.35rem);
    font-weight: 700;
    opacity: 1;
    transition: opacity 280ms ease, transform 280ms ease;
}

.page-audio-unlock__content [data-page-audio-unlock-button][hidden] {
    opacity: 0;
    transform: translateY(8px);
}

.page-audio-unlock__content [data-page-audio-unlock-button]:not([hidden]) {
    animation: page-audio-unlock-fade-in 320ms ease;
}

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

@keyframes page-audio-unlock-fade-in {
    from {
        opacity: 0;
        transform: translateY(8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.prayer-chat__panel {
    display: grid;
    gap: 14px;
}

.chat-bubble {
    max-width: min(88%, 420px);
    padding: 16px 18px;
    border-radius: 22px;
    box-shadow: var(--shadow-sm), 0 6px 16px rgba(29, 27, 32, 0.06);
}

.chat-bubble h1,
.chat-bubble p {
    margin: 0;
}

.chat-bubble h1 {
    font-size: clamp(1.8rem, 5vw, 2.4rem);
    line-height: 1.08;
    margin-top: 4px;
}

.chat-bubble p+p {
    margin-top: 8px;
}

.chat-bubble--assistant {
    justify-self: start;
    background: rgba(255, 255, 255, 0.82);
    color: var(--text);
    border-top-left-radius: 8px;
}

.chat-bubble--user {
    justify-self: end;
    background: var(--primary);
    color: #ffffff;
    border-top-right-radius: 8px;
}

.chat-bubble--system {
    justify-self: stretch;
    max-width: none;
    background: rgba(244, 239, 255, 0.9);
    border-radius: 24px;
}

.chat-choice-grid {
    display: grid;
    gap: 12px;
    align-content: start;
    width: 75%;
    margin-left: auto;
}

.chat-choice {
    width: 100%;
    min-height: 58px;
    max-height: 58px;
    justify-content: center;
    border-radius: 22px;
    white-space: normal;
    text-align: center;
    line-height: 1.25;
}

.chat-composer {
    gap: 12px;
}

.chat-composer--fixed {
    position: fixed;
    left: 0;
    right: 0;
    bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    z-index: 18;
    width: calc(100% - 24px);
    max-width: 456px;
    margin: 0 auto;
}

.chat-composer__bar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
    padding: 10px;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 18px 34px rgba(29, 27, 32, 0.14);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
}

.chat-composer__input {
    min-height: 46px;
    border: 0;
    margin-top: 0;
    background: transparent;
    box-shadow: none;
    padding: 0 6px 0 10px;
}

.chat-composer__input:focus {
    box-shadow: none;
}

.chat-composer__send {
    width: 48px;
    min-width: 48px;
    height: 48px;
    padding: 0;
    border-radius: 9999px;
}

.chat-actions--inline {
    justify-content: flex-start;
}

.chat-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.chat-actions .btn {
    flex: 1 1 180px;
}

.chat-actions--inline .btn {
    flex: 0 0 auto;
}

.floating-back-btn {
    position: sticky;
    top: calc(12px + env(safe-area-inset-top, 0px));
    z-index: 12;
    margin: 0 0 12px;
    width: fit-content;
    min-height: 44px;
    padding: 0 16px 0 12px;
    border-radius: 9999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: rgba(255, 255, 255, 0.9);
    color: var(--primary);
    box-shadow: 0 12px 30px rgba(29, 27, 32, 0.16);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
}

.floating-page-actions {
    position: sticky;
    top: calc(12px + env(safe-area-inset-top, 0px));
    z-index: 12;
    margin: 0 0 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.floating-page-actions .floating-back-btn {
    position: static;
    top: auto;
    margin: 0;
}

.floating-audio-btn {
    min-height: 44px;
    padding: 0 16px 0 12px;
    border: 0;
    border-radius: 9999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: rgba(255, 255, 255, 0.9);
    color: var(--primary);
    box-shadow: 0 12px 30px rgba(29, 27, 32, 0.16);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    font: inherit;
    cursor: pointer;
}

.floating-audio-btn:hover,
.floating-audio-btn:focus-visible {
    background: #ffffff;
    transform: translateY(-1px);
}

.floating-audio-btn .nav-icon {
    width: 20px;
    height: 20px;
}

.floating-back-btn:hover,
.floating-back-btn:focus-visible {
    background: #ffffff;
    transform: translateY(-1px);
}

.floating-back-btn .nav-icon {
    width: 20px;
    height: 20px;
}

.prayer-paths {
    display: grid;
    gap: 16px;
}

.chat-actions__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    align-content: start;
}

.prayer-path-picker {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.prayer-path-picker .btn {
    width: 100%;
    justify-content: center;
}

.prayer-path-card {
    padding: 20px;
}

.feeling-fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

.feeling-fieldset legend {
    font-weight: 600;
    margin-bottom: 10px;
}

.feeling-chip-grid {
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
}

.feeling-fieldset {
    width: 75%;
    margin-left: auto;
}

.feeling-chip {
    position: relative;
    justify-content: center;
    text-align: center;
    cursor: pointer;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: var(--shadow-sm), 0 6px 16px rgba(29, 27, 32, 0.06);
    border-radius: 18px;
    min-height: 54px;
}

.feeling-chip input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.feeling-chip:has(input:checked) {
    background: var(--secondary-hover);
    box-shadow: inset 0 0 0 1px var(--primary);
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.inline-actions {
    display: flex;
    gap: 10px;
    align-items: center;
}

.inline-actions.wrap {
    flex-wrap: wrap;
}

.prayer-today-actions>.btn {
    flex: 1 1 100%;
    width: 100%;
    white-space: normal;
    text-align: center;
    line-height: 1.3;
    min-height: 56px;
    flex-direction: column;
    align-items: center;
    padding-top: 14px;
    padding-bottom: 14px;
    border-radius: 24px;
}

.prayer-today-actions>.btn>span:first-child {
    font-size: 1.2rem;
    font-weight: 700;
}

.prayer-today-actions .btn-subtext {
    font-size: .74rem;
    font-weight: 500;
    line-height: 1.35;
    opacity: .9;
}

.prayer-tabs {
    gap: 18px;
}

.prayer-tabs__radio {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.prayer-tabs__nav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    padding: 6px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.36);
}

.prayer-tabs__tab {
    min-height: 44px;
    display: grid;
    place-items: center;
    padding: 10px 12px;
    border-radius: 18px;
    color: var(--muted);
    text-align: center;
    font-size: 0.88rem;
    font-weight: 600;
    cursor: pointer;
}

.feeling-btn {
    background: #fff;
    border-radius: 12px;
    padding: 6px;
    text-align: center;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
    cursor: pointer;
    border: 2px solid transparent;
    transition: all 0.2s ease;
}

.prayer-tabs__panel {
    display: none;
}

#prayer-tab-recent:checked~.prayer-tabs__nav label[for="prayer-tab-recent"],
#prayer-tab-saved:checked~.prayer-tabs__nav label[for="prayer-tab-saved"] {
    background: var(--primary);
    color: #ffffff;
    box-shadow: 0 8px 18px rgba(37, 21, 84, 0.18);
}

#prayer-tab-recent:checked~.prayer-tabs__panel--recent,
#prayer-tab-saved:checked~.prayer-tabs__panel--saved {
    display: block;
}

.stats-grid {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.stat-card {
    padding: 18px;
    min-height: 120px;
    display: grid;
    align-content: space-between;
}

.stat-label {
    color: var(--muted);
    font-size: .85rem;
}

.stat-card strong {
    font-size: 1.6rem;
}

article.stat-card {
    background: rgba(255, 255, 255, 0.5);
    border: none;
}

.verse-block,
.notice {
    padding: 18px;
    border-radius: 20px;
    background: rgba(255, 255, 255, .45);
    box-shadow: var(--shadow-sm), 0 4px 12px rgba(29, 27, 32, 0.04);
}

.verse-block p {
    margin: 8px 0 0;
}

.prayer-text-box {
    padding: 18px;
    border-radius: 20px;
    background: rgba(255, 255, 255, .45);
    box-shadow: var(--shadow-sm), 0 4px 12px rgba(29, 27, 32, 0.04);
}

.prayer-detail-card {
    padding-top: 20px;
    padding-bottom: 20px;
}

.prayer-audio-card {
    opacity: 0;
    transform: translateY(-10px);
    transition: opacity .28s ease, transform .28s ease;
}

.prayer-audio-card.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.prayer-actions {
    margin-top: 18px;
    align-items: stretch;
    gap: 12px;
}

.prayer-audio-actions {
    margin-top: 12px;
    align-items: stretch;
    gap: 12px;
}

.prayer-action-primary,
.prayer-action-slot {
    flex: 1 1 calc(50% - 6px);
    min-width: 0;
}

.prayer-action-slot {
    display: flex;
}

.prayer-action-slot .btn,
.prayer-action-primary {
    width: 100%;
    min-width: 0;
    white-space: nowrap;
}

.prayer-action-slot-full {
    flex-basis: 100%;
}

.prayer-action-slot-full .btn {
    white-space: normal;
}

.prayer-notes-card .field {
    margin-top: 4px;
}

.card.prayer-card,
.card.prayer-detail-card,
.card.prayer-audio-card,
.card.prayer-notes-card {
    background: rgba(255, 255, 255, 0.18) !important;
    border: 1px solid rgba(255, 255, 255, 0.28) !important;
    -webkit-backdrop-filter: blur(18px);
    backdrop-filter: blur(18px);
    box-shadow: 0 18px 40px rgba(29, 27, 32, 0.12), 0 0 0 1px rgba(255, 255, 255, 0.08) inset !important;
}

.prayer-text {
    margin: 0;
    white-space: normal;
}

.prayer-note-entry {
    position: relative;
    padding-bottom: 42px;
}

.prayer-note-delete {
    position: absolute;
    right: 12px;
    bottom: 12px;
}

.prayer-note-delete__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--muted);
    cursor: pointer;
}

.prayer-note-delete__button:hover,
.prayer-note-delete__button:focus-visible {
    color: var(--danger);
}

.prayer-card .eyebrow {
    color: #ffffff;
}

.history-item,
.kv {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
}

.history-card-link {
    display: grid;
    color: inherit;
}

.history-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    color: var(--muted);
    font-size: .92rem;
}

.history-item a {
    color: inherit;
}

.admin-user-list {
    display: grid;
    gap: 12px;
}

.admin-user-row,
.admin-user-row:visited {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
    color: inherit;
    text-decoration: none;
}

.admin-user-meta {
    display: grid;
    gap: 4px;
    text-align: right;
}

.prayer-days-strip {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 10px;
    align-items: start;
    margin-bottom: 10px;
}

.prayer-day {
    display: grid;
    justify-items: center;
    gap: 8px;
}

.prayer-day__weekday {
    font-size: .82rem;
    font-weight: 600;
    text-transform: lowercase;
    color: var(--muted);
}

.prayer-day__bubble {
    width: 42px;
    height: 42px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: rgba(255, 255, 255, .55);
    color: var(--muted);
    font-weight: 700;
    box-shadow: var(--shadow-sm);
}

.prayer-day.is-prayed .prayer-day__bubble {
    background: var(--primary);
    color: #ffffff;
}

.steps {
    margin: 0;
    padding-left: 20px;
    display: grid;
    gap: 8px;
}

.paypal-shell {
    min-height: 60px;
}

.topbar a:focus-visible,
.btn:focus-visible,
.field:focus-visible,
.segment:focus-within,
.chip:focus-within {
    outline: none;
    box-shadow: var(--shadow-sm), 0 10px 22px rgba(103, 80, 164, 0.22);
}

.card,
.btn {
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1) !important;
}

.home-focus__copy h1 {
    font-size: 25px;
}

.home-focus__cta {
    font-size: 18px;
    color: var(--primary-active);
    background: #fff;
    box-shadow: 0 0 10px (0, 0, 0, 0.5) !important;
    height: 60px;
    width: 250px;
}

.home-focus__cta:hover {
    color: var(--primary-active);
    background: #fff;
    transform: scale(1.1);
    box-shadow: 0 0 30px (0, 0, 0, 0.8) !important;
}

.feeling-chip-grid {
    padding: 10px;
}


@media (min-width: 780px) {
    .hero {
        grid-template-columns: 1.15fr .85fr;
        align-items: stretch;
    }

    .bottom-nav {
        left: 50%;
        right: auto;
        width: min(560px, calc(100% - 24px));
        transform: translateX(-50%);
    }
}

@media (hover: none) {
    .card:hover {
        transform: none;
        box-shadow: var(--shadow-sm), 0 6px 18px rgba(29, 27, 32, 0.05);
    }
}

.is-ios-safari .ambient {
    filter: blur(40px);
    opacity: .16;
}

.is-ios-safari .topbar,
.is-ios-safari .bottom-nav {
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
}

.is-ios-safari .splash-page__logo {
    animation-duration: 1.6s;
}

.is-ios-safari .settings-time-field {
    min-width: 0;
}

.settings-time-field .field[type="time"] {
    width: 100%;
    -webkit-appearance: none;
    appearance: none;
    text-align: left;
}

.is-ios-safari .settings-time-field .field[type="time"] {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    display: block;
    box-sizing: border-box;
    -webkit-appearance: none;
    appearance: none;
    padding-right: 16px;
}

.is-ios-safari .loading-screen,
.is-ios-safari .loading-screen__content,
.is-ios-safari .loading-screen__dots span,
.is-ios-safari .splash-page__logo {
    -webkit-transform: translateZ(0);
}

.login-form .inline-actions .btn {
    width: 50%;
}

.page {
    margin: 0;
    width: 100%;
    padding: 0 24px 120px 24px;
}

.app-shell--checkin {
    display: flex;
    flex-direction: column;
    height: 100svh;
    height: var(--vv-height, 100svh);
    overflow: hidden;
}

.app-shell--composing {
    height: auto !important;
    min-height: 100vh;
    overflow-y: visible !important;
    overflow-x: clip !important;
}

.page.page--checkin {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    padding-bottom: 24px !important;
}

.hero.compact {
    border: none;
    background: none;
    box-shadow: none;
    padding: 0 24px;
}

.bottom-nav {
    background: rgba(255, 255, 255, 0.5);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}

.page-header h1 {
    margin: 0 24px;
}

.ambient {
    background: #fff;
    opacity: 0.5;
}

.ambient-2 {
    background: #000 !important;
}

.ambient-4 {
    width: 200px;
    height: 200px;
    bottom: 0px;
    right: -20px;
    background: #000 !important;
}

.card {
    background: rgba(255, 255, 255, 0.5)
}

.home-focus__cloud {
    height: 80px;
    filter: blur(15px);
}

.home-focus__copy {
    text-shadow: 0 0 15px rgba(0, 0, 0, 0.2);
}

.home-focus__copy h1 {
	font-size: 35px!important;
}
.home-focus p {
    font-size: 1.2rem;
    text-shadow: 0 0 10px rgba(0,0,0,0.15);
}

.onboarding-flow {
    min-height: calc(100svh - 96px);
    display: flex;
    align-items: stretch;
    color: #fff;
}

.onboarding-shell {
    position: relative;
    width: 100%;
    min-height: calc(100svh - 96px);
    display: flex;
    flex-direction: column;
}

.onboarding-screen {
    display: flex;
    flex: 1 1 auto;
    min-height: 0;
    padding: 140px 0 98px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 220ms ease;
    position: absolute;
    inset: 0;
}

.onboarding-screen.is-active {
    flex-direction: column;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.onboarding-screen__body {
    flex: 1 1 auto;
    display: grid;
    align-content: start;
    gap: 12px;
}

.onboarding-screen__body--center {
    align-content: center;
}

.onboarding-screen--intro .onboarding-screen__body {
    justify-items: center;
    text-align: center;
}

.onboarding-intro-stage {
    position: relative;
    min-height: 100%;
    width: 100%;
    overflow: visible;
}

.onboarding-intro-copy-wrap {
    width: 100%;
    min-height: 100%;
    display: grid;
    place-items: center;
    will-change: opacity;
    backface-visibility: hidden;
    -webkit-font-smoothing: antialiased;
}

.onboarding-screen--intro-left .onboarding-intro-copy-wrap {
    justify-items: start;
    text-align: left;
}

.onboarding-screen--intro-right .onboarding-intro-copy-wrap {
    justify-items: end;
    text-align: right;
}

.onboarding-screen--intro-center .onboarding-intro-copy-wrap {
    justify-items: center;
    text-align: center;
}

.onboarding-screen--intro .onboarding-intro-copy {
    display: inline-block;
    will-change: transform;
    backface-visibility: hidden;
    -webkit-font-smoothing: antialiased;
    transform: translate3d(var(--intro-pan-x, 0px), var(--intro-pan-y, 0px), 0);
}

.onboarding-flow.is-page-audio-unlocked .onboarding-screen--intro.is-active .onboarding-intro-copy {
    animation: onboarding-intro-copy-pan var(--intro-duration, 24s) linear forwards;
}

.onboarding-screen__body h1 {
    margin: 0;
    font-size: clamp(2rem, 7vw, 2.8rem);
    line-height: 1.08;
    color: #fff;
}

.onboarding-screen__body p {
    margin: 0;
    color: #fff;
}

.onboarding-question {
    color: #fff;
}

.onboarding-helper {
    color: rgba(255,255,255,0.86);
    font-size: 0.95rem;
}

@keyframes onboarding-intro-copy-pan {
    from {
        opacity: 0;
        transform: translate3d(var(--intro-pan-x, 0px), var(--intro-pan-y, 0px), 0);
    }
    12% {
        opacity: 1;
    }
    88% {
        opacity: 1;
    }
    to {
        opacity: 0.92;
        transform: translate3d(calc(var(--intro-pan-x, 0px) + var(--intro-travel-x, 0px)), calc(var(--intro-pan-y, 0px) + var(--intro-travel-y, 0px)), 0);
    }
}

.onboarding-screen--intro .onboarding-screen__body h1 {
    font-size: clamp(2.8rem, 11vw, 4.4rem);
    line-height: 1.02;
    max-width: min(88vw, 720px);
}

.onboarding-choice-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.onboarding-choice {
    min-height: 44px;
    padding: 10px 12px;
    border-radius: 18px;
    background: rgba(255,255,255,0.72);
    color: var(--text);
    box-shadow: var(--shadow-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    position: relative;
    cursor: pointer;
}

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

.onboarding-choice:has(input:checked) {
    background: var(--secondary-active);
    color: var(--primary-active);
    box-shadow: inset 0 0 0 1px var(--primary);
}

.onboarding-note-field {
    min-height: 150px;
    margin-top: 4px;
}

.onboarding-time-field {
    width: calc(100vw - 48px);
    max-width: 100%;
    min-height: 72px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 10px;
    padding: 0 18px;
    border-radius: 22px;
    font-size: clamp(1.35rem, 6vw, 1.8rem);
    font-weight: 700;
    text-align: center;
}

.onboarding-actions {
    position: fixed;
    left: 24px;
    right: 24px;
    bottom: calc(18px + env(safe-area-inset-bottom, 0px));
    z-index: 22;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    max-width: 432px;
    margin: 0 auto;
}

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

.settings-editable__header label {
    font-weight: 600;
}

.settings-editable__toggle,
.settings-editable__cancel {
    min-height: 36px;
    padding: 0 14px;
}

.settings-answer {
    margin: 0;
    color: var(--text);
}

.settings-editable__panel {
    opacity: 0;
    transform: translateX(24px);
    transition: opacity 220ms ease, transform 220ms ease;
}

.settings-editable__panel.is-open {
    opacity: 1;
    transform: translateX(0);
}

.settings-editable__panel[hidden],
.settings-editable__cancel[hidden],
.settings-editable__toggle[hidden] {
    display: none !important;
}

.onboarding-shell::after {
    content: "";
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    height: 180px;
    background: linear-gradient(to bottom, rgba(0,0,0,0), rgba(0,0,0,0.2));
    pointer-events: none;
    z-index: 21;
}

.onboarding-actions--single {
    grid-template-columns: 1fr;
}

.onboarding-actions--single .btn-primary {
    background: #fff;
    color: var(--primary);
    box-shadow: 0 18px 32px rgba(0,0,0,0.22);
}

.onboarding-actions--single .btn-primary:hover,
.onboarding-actions--single .btn-primary:focus-visible {
    background: rgba(255,255,255,0.96);
    color: var(--primary);
}

.onboarding-actions--triple {
    grid-template-columns: 1fr 1fr;
}

.onboarding-actions .btn {
    min-height: 52px;
}

.onboarding-actions .btn-primary {
    background: #ffffff;
    color: var(--primary);
    box-shadow: 0 16px 28px rgba(0,0,0,0.18);
}

.onboarding-actions .btn-primary:hover,
.onboarding-actions .btn-primary:focus-visible {
    background: rgba(255,255,255,0.96);
    color: var(--primary);
}

.onboarding-back-button {
    justify-self: start;
    align-self: center;
    min-height: auto !important;
    padding: 0;
    border: 0;
    background: transparent;
    color: #ffffff;
    text-decoration: underline;
    text-underline-offset: 3px;
    box-shadow: none;
    font-weight: 600;
}

.onboarding-back-button:hover,
.onboarding-back-button:focus-visible {
    background: transparent;
    color: rgba(255,255,255,0.92);
    box-shadow: none;
}

.onboarding-back-link {
    color: #ffffff;
    text-align: left;
    padding: 0 20px;
    font-weight: 600;
    opacity: 1;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.onboarding-back-link:hover,
.onboarding-back-link:focus-visible {
    opacity: 1;
}
.home-focus__cta {
	margin-top: 25vh;
}

.app-shell,
.bottom-nav {
    max-width: 480px;
    margin: 0 auto;
}

.chat-choice-grid,
.chat-actions {
    background: #E8E2F5;
    padding: 10px;
    border-radius: var(--radius-lg);
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
    transition: transform 0.1s ease-in-out;
}

.btn:active {
    transform: scale(0.95);
    box-shadow: none !important;
    border: 1px solid var(--primary);
}

@media (max-width: 419px) {
    html {
        font-size: 15px;
    }

    .brand {
        font-size: 18px;
    }

    .hero-copy h1,
    .page-header h1,
    .card h1 {
        font-size: clamp(1.8rem, 6vw, 2.3rem);
    }

    .btn {
        font-size: 14px;
    }

    .prayer-today-actions>.btn>span:first-child {
        font-size: .94rem;
    }

    .prayer-today-actions .btn-subtext,
    .bottom-nav__item,
    .stat-label,
    .history-meta,
    .prayer-day__weekday,
    .eyebrow {
        font-size: .72rem;
    }

    .stat-card strong {
        font-size: 1.42rem;
    }

    .home-focus__cta {
        font-size: 18px;
    }
}

@media (max-width: 319px) {
    .two-up {
        grid-template-columns: 1fr;
    }
}

@media (prefers-reduced-motion: reduce) {

    *,
    *::before,
    *::after {
        animation: none !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}
