@media (max-width: 767.98px) {
    html {
        background: var(--av-bg);
    }

    body {
        background: var(--av-bg);
        color: var(--av-text);
        -webkit-tap-highlight-color: transparent;
    }

    .mobile-app-shell {
        background: var(--av-bg);
    }

    .mobile-app-content {
        padding-bottom: calc(86px + env(safe-area-inset-bottom));
    }

    .top-app-bar {
        min-height: 66px;
        border-bottom: 1px solid rgba(15, 23, 42, .06);
        background: color-mix(in srgb, var(--av-surface) 92%, transparent);
        backdrop-filter: blur(18px);
    }

    .top-app-bar-logo {
        width: 54px;
        height: 42px;
        border-radius: 14px;
    }

    .top-app-bar-title {
        color: var(--av-text);
        font-size: 1rem;
        font-weight: 850;
    }

    .top-app-bar-sub {
        max-width: 180px;
        overflow: hidden;
        text-overflow: ellipsis;
        color: color-mix(in srgb, var(--av-text) 62%, transparent);
        white-space: nowrap;
    }

    .app-screen {
        padding: 14px 14px 24px;
        background: var(--av-bg);
        border-radius: 0;
        box-shadow: none;
    }

    .app-page-header {
        display: grid;
        gap: .9rem;
        margin: 0 0 1rem;
        padding: 0;
    }

    .app-page-title {
        color: var(--av-text);
        font-size: clamp(1.55rem, 7vw, 2.25rem);
        line-height: 1.05;
        letter-spacing: 0;
    }

    .app-page-subtitle {
        color: color-mix(in srgb, var(--av-text) 68%, transparent);
        font-size: .98rem;
        line-height: 1.35;
    }

    .app-page-header__actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: .65rem;
    }

    .btn,
    button {
        touch-action: manipulation;
    }

    .btn-primary,
    .btn-success,
    .vote-btn--primary {
        border-color: transparent !important;
        background: linear-gradient(135deg, var(--av-primary), var(--av-secondary)) !important;
        color: #fff !important;
        box-shadow: 0 14px 30px color-mix(in srgb, var(--av-secondary) 28%, transparent);
    }

    .btn-outline-secondary,
    .vote-btn--secondary,
    .vote-btn--ghost {
        border-color: color-mix(in srgb, var(--av-text) 14%, transparent) !important;
        background: var(--av-surface) !important;
        color: var(--av-text) !important;
    }

    .av-bottom-nav {
        position: fixed;
        right: 12px;
        bottom: calc(10px + env(safe-area-inset-bottom));
        left: 12px;
        z-index: 1030;
        display: grid;
        grid-template-columns: repeat(5, 1fr);
        gap: 4px;
        min-height: 66px;
        padding: 8px;
        border: 1px solid rgba(15, 23, 42, .08);
        border-radius: 24px;
        background: color-mix(in srgb, var(--av-surface) 94%, transparent);
        box-shadow: 0 18px 42px rgba(15, 23, 42, .16);
        backdrop-filter: blur(20px);
    }

    .av-bottom-nav a {
        display: grid;
        place-items: center;
        gap: 2px;
        min-width: 0;
        border-radius: 18px;
        color: color-mix(in srgb, var(--av-text) 62%, transparent);
        font-size: .68rem;
        font-weight: 800;
        text-decoration: none;
    }

    .av-bottom-nav i {
        font-size: 1.1rem;
    }

    .av-bottom-nav a.is-active {
        background: color-mix(in srgb, var(--av-secondary) 14%, var(--av-surface));
        color: var(--av-primary);
    }

    .voter-dashboard .card,
    .agenda-board,
    .votes-mobile-card {
        border: 1px solid color-mix(in srgb, var(--av-text) 9%, transparent) !important;
        border-radius: var(--av-radius) !important;
        background: var(--av-surface) !important;
        box-shadow: 0 16px 36px rgba(15, 23, 42, .08) !important;
    }

    .voter-dashboard__summary {
        display: none !important;
    }

    .voter-mobile-hero {
        display: grid;
        gap: 1rem;
        margin-bottom: 1rem;
        padding: 18px;
        border-radius: calc(var(--av-radius) + 8px);
        background:
            radial-gradient(circle at top right, color-mix(in srgb, var(--av-accent) 25%, transparent), transparent 36%),
            linear-gradient(135deg, var(--av-primary), var(--av-secondary));
        color: #fff;
        box-shadow: 0 22px 50px color-mix(in srgb, var(--av-secondary) 28%, transparent);
    }

    .voter-mobile-hero span {
        display: block;
        margin-bottom: .35rem;
        opacity: .78;
        font-size: .78rem;
        font-weight: 800;
        text-transform: uppercase;
    }

    .voter-mobile-hero strong {
        display: block;
        font-size: 1.35rem;
        line-height: 1.08;
    }

    .voter-mobile-hero p {
        margin: .55rem 0 0;
        opacity: .82;
    }

    .voter-mobile-hero .btn {
        min-height: 52px;
        border: 0 !important;
        background: #fff !important;
        color: var(--av-primary) !important;
        border-radius: 999px;
        font-weight: 900;
    }

    .voter-dashboard .card-header {
        border-bottom-color: color-mix(in srgb, var(--av-text) 8%, transparent);
        background: var(--av-surface) !important;
        color: var(--av-text);
    }

    .agenda-board {
        display: grid;
        gap: .9rem;
        padding: 0 !important;
        border: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
    }

    .agenda-assembly {
        display: grid;
        gap: .75rem;
    }

    .agenda-assembly-title {
        color: color-mix(in srgb, var(--av-text) 72%, transparent);
        font-size: .82rem;
        text-transform: uppercase;
    }

    .agenda-point {
        display: grid !important;
        grid-template-columns: 1fr;
        gap: .85rem;
        padding: 16px !important;
        border-radius: var(--av-radius) !important;
        background: var(--av-surface) !important;
        color: var(--av-text);
    }

    .agenda-point.is-active {
        border-color: color-mix(in srgb, var(--av-success) 50%, transparent) !important;
        background: color-mix(in srgb, var(--av-success) 9%, var(--av-surface)) !important;
    }

    .agenda-point:target {
        border-color: var(--av-secondary) !important;
        box-shadow: 0 0 0 4px color-mix(in srgb, var(--av-secondary) 16%, transparent) !important;
    }

    .agenda-point-title {
        color: var(--av-text);
        font-size: 1.05rem;
        line-height: 1.18;
    }

    .agenda-point-desc {
        color: color-mix(in srgb, var(--av-text) 62%, transparent) !important;
        font-size: .92rem !important;
        line-height: 1.35;
    }

    .badge-soft {
        border-radius: 999px;
        font-size: .7rem;
        letter-spacing: 0;
    }

    .badge-soft.ok {
        background: color-mix(in srgb, var(--av-success) 14%, var(--av-surface)) !important;
        color: var(--av-success) !important;
    }

    .badge-soft.warn {
        background: color-mix(in srgb, var(--av-warning) 18%, var(--av-surface)) !important;
        color: #9a5b00 !important;
    }

    .badge-soft.muted {
        background: color-mix(in srgb, var(--av-text) 8%, var(--av-surface)) !important;
        color: color-mix(in srgb, var(--av-text) 72%, transparent) !important;
    }
}

@media (min-width: 768px) {
    .av-bottom-nav {
        display: none;
    }

    .voter-mobile-hero {
        display: none;
    }
}

@media (max-width: 767.98px) {
    html:has(body.voter-app-body) {
        width: 100%;
        min-height: 100%;
        margin: 0;
        padding: 0;
        overflow-x: hidden;
        background: var(--av-bg);
    }

    body.voter-app-body {
        width: 100%;
        min-width: 0;
        min-height: 100dvh;
        margin: 0;
        padding: 0;
        overflow-x: hidden;
        background: var(--av-bg);
    }

    body.voter-app-body,
    body.voter-app-body * {
        box-sizing: border-box;
    }

    body.voter-app-body .mobile-app-shell {
        width: 100% !important;
        max-width: none !important;
        min-height: calc(100dvh - 66px) !important;
        margin: 0 !important;
        padding: 0 !important;
        background: var(--av-bg) !important;
    }

    body.voter-app-body .mobile-app-content {
        width: 100% !important;
        max-width: none !important;
        min-height: calc(100dvh - 66px) !important;
        margin: 0 !important;
        padding: 0 0 calc(96px + env(safe-area-inset-bottom)) !important;
        overflow-x: hidden !important;
        background: var(--av-bg) !important;
    }

    body.voter-app-body .mobile-app-content > .container,
    body.voter-app-body .mobile-app-content > .container-sm,
    body.voter-app-body .mobile-app-content > .container-md,
    body.voter-app-body .mobile-app-content > .container-lg,
    body.voter-app-body .mobile-app-content > .container-xl,
    body.voter-app-body .mobile-app-content > .container-xxl {
        width: 100% !important;
        max-width: none !important;
        margin: 0 !important;
        padding-right: 0 !important;
        padding-left: 0 !important;
    }

    body.voter-app-body .app-screen {
        width: 100% !important;
        max-width: none !important;
        min-height: calc(100dvh - 66px - 96px - env(safe-area-inset-bottom)) !important;
        margin: 0 !important;
        padding: 14px 14px 24px !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: var(--av-bg) !important;
        box-shadow: none !important;
        overflow: visible !important;
    }

    body.voter-app-body.app-fullscreen-mobile .mobile-app-shell,
    body.voter-app-body.app-fullscreen-mobile .mobile-app-content {
        min-height: 100dvh !important;
    }

    body.voter-app-body.app-fullscreen-mobile .mobile-app-content {
        padding-bottom: 0 !important;
    }

    body.voter-app-body.app-fullscreen-mobile .vote-shell--app {
        min-height: 100dvh !important;
    }

    body.voter-app-body .top-app-bar {
        position: sticky;
        top: 0;
        z-index: 1040;
        width: 100%;
        max-width: 100%;
        margin: 0;
        border-radius: 0;
    }

    body.voter-app-body .av-bottom-nav {
        right: 0 !important;
        bottom: 0 !important;
        left: 0 !important;
        width: 100% !important;
        min-height: calc(72px + env(safe-area-inset-bottom)) !important;
        padding: 8px 8px calc(8px + env(safe-area-inset-bottom)) !important;
        border-right: 0 !important;
        border-bottom: 0 !important;
        border-left: 0 !important;
        border-radius: 22px 22px 0 0 !important;
    }
}
