/* Agendamobily v4.5.1 - camada mobile profissional e anti-cache PWA */
:root {
    --agdm-bg: #f7f8fc;
    --agdm-surface: #ffffff;
    --agdm-text: #0b1533;
    --agdm-muted: #768196;
    --agdm-border: #e7ebf3;
    --agdm-primary: #4f46e5;
    --agdm-primary-2: #2454d6;
    --agdm-shadow: 0 18px 42px rgba(15, 23, 42, .075);
    --agdm-red: #ef4444;
    --agdm-orange: #f59e0b;
    --agdm-green: #10b981;
}

/* desktop permanece com o CSS principal; esta camada prioriza telas pequenas */
@media (max-width: 991.98px) {
    html, body {
        background: linear-gradient(180deg, #ffffff 0%, var(--agdm-bg) 38%, var(--agdm-bg) 100%) !important;
    }

    body.agenda-layout {
        margin: 0 !important;
        min-height: 100vh;
        overflow-x: hidden;
        color: var(--agdm-text);
        font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    }

    .topbar,
    .main-sidebar,
    .sidebar-backdrop,
    #sidebarToggle {
        display: none !important;
        visibility: hidden !important;
        pointer-events: none !important;
    }

    .content-wrapper,
    body.sidebar-collapsed .content-wrapper,
    body.sidebar-expanded .content-wrapper {
        margin-left: 0 !important;
        padding: calc(18px + env(safe-area-inset-top)) 14px calc(116px + env(safe-area-inset-bottom)) !important;
        min-height: 100vh;
    }

    .daily-app-screen,
    .monthly-section,
    .support-section {
        width: 100%;
        max-width: 100% !important;
        margin-left: auto;
        margin-right: auto;
    }

    .daily-app-screen {
        margin-bottom: 18px;
    }

    .daily-app-header {
        display: flex !important;
        align-items: flex-start;
        justify-content: space-between;
        gap: 12px;
        margin: 0 0 18px;
    }

    .daily-kicker {
        display: block;
        color: #8b95a8;
        font-weight: 800;
        font-size: .82rem;
        margin-bottom: 4px;
    }

    .daily-date-block h1 {
        margin: 0;
        color: #08122b;
        font-size: 1.85rem;
        line-height: 1.03;
        font-weight: 900;
        letter-spacing: -.055em;
    }

    .daily-header-actions {
        display: flex;
        gap: 8px;
    }

    .daily-action-button {
        position: relative;
        width: 43px;
        height: 43px;
        display: inline-grid !important;
        place-items: center;
        border: 1px solid rgba(226, 232, 240, .9);
        border-radius: 16px;
        color: var(--agdm-primary);
        background: #fff;
        text-decoration: none !important;
        box-shadow: 0 12px 28px rgba(15, 23, 42, .055);
    }

    .daily-alert-dot {
        position: absolute;
        top: -6px;
        right: -5px;
        min-width: 19px;
        height: 19px;
        padding: 0 5px;
        display: grid;
        place-items: center;
        border-radius: 99px;
        background: var(--agdm-red);
        color: #fff;
        font-size: .66rem;
        font-weight: 900;
        border: 2px solid #fff;
    }

    .filter-bar-mobile {
        display: block !important;
        margin: 0 0 16px;
        padding: 14px;
        border-radius: 22px;
    }

    .day-strip {
        display: grid !important;
        grid-auto-flow: column;
        grid-auto-columns: 70px;
        gap: 10px;
        overflow-x: auto;
        padding: 4px 2px 16px;
        scrollbar-width: none;
    }

    .day-strip::-webkit-scrollbar { display: none; }

    .day-chip {
        min-height: 74px;
        display: flex !important;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 4px;
        border: 1px solid rgba(226, 232, 240, .95);
        border-radius: 20px;
        color: #626d84 !important;
        background: #fff;
        text-decoration: none !important;
        box-shadow: 0 10px 24px rgba(15, 23, 42, .045);
    }

    .day-chip span {
        font-size: .75rem;
        font-weight: 850;
        line-height: 1;
    }

    .day-chip strong {
        color: #111c35;
        font-size: 1.28rem;
        line-height: 1;
        font-weight: 900;
        letter-spacing: -.04em;
    }

    .day-chip.active {
        color: #fff !important;
        border-color: transparent;
        background: linear-gradient(145deg, #2454d6, #5b35ee) !important;
        box-shadow: 0 18px 36px rgba(37, 84, 214, .33);
    }

    .day-chip.active strong { color: #fff; }
    .day-chip.is-today:not(.active) { border-color: #c7d2fe; background: #f8faff; }

    .daily-summary-strip {
        display: grid !important;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 7px;
        margin: 0 0 14px;
    }

    .daily-summary-strip div {
        min-height: 64px;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 3px;
        border-radius: 18px;
        border: 1px solid rgba(226, 232, 240, .92);
        background: rgba(255, 255, 255, .9);
        box-shadow: 0 10px 22px rgba(15, 23, 42, .045);
    }

    .daily-summary-strip strong {
        color: #101b35;
        font-size: 1.16rem;
        line-height: 1;
        font-weight: 900;
    }

    .daily-summary-strip span {
        color: #687389;
        font-size: .62rem;
        font-weight: 850;
    }

    .daily-summary-strip .danger strong,
    .daily-summary-strip .danger span { color: var(--agdm-red); }

    .next-focus-card {
        position: relative;
        display: flex !important;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        overflow: hidden;
        border: 1px solid rgba(226, 232, 240, .9);
        border-radius: 22px;
        padding: 14px 13px 14px 18px;
        margin: 0 0 16px;
        background: #fff;
        box-shadow: var(--agdm-shadow);
    }

    .next-focus-card::before {
        content: '';
        position: absolute;
        inset: 0 auto 0 0;
        width: 5px;
        background: var(--priority-color, var(--agdm-orange));
    }

    .next-focus-card span,
    .next-focus-card small {
        display: block;
        color: #717b90;
        font-weight: 750;
    }

    .next-focus-card strong {
        display: block;
        color: #101b35;
        font-size: 1rem;
        font-weight: 900;
        margin: 2px 0;
    }

    .next-focus-card a {
        flex: 0 0 auto;
        border-radius: 999px;
        padding: 8px 12px;
        color: var(--agdm-primary) !important;
        background: #eef2ff;
        font-weight: 900;
        text-decoration: none !important;
    }

    .agenda-card,
    .timeline-panel,
    .monthly-section {
        background: #fff;
        border: 1px solid rgba(226, 232, 240, .9);
        border-radius: 24px;
        box-shadow: var(--agdm-shadow);
    }

    .timeline-panel,
    .monthly-section {
        padding: 14px 12px;
        margin-inline: 0;
    }

    .timeline-heading {
        display: flex !important;
        justify-content: space-between;
        align-items: flex-start;
        gap: 12px;
        margin-bottom: 12px;
    }

    .timeline-heading h2 {
        margin: 0;
        color: #101b35;
        font-size: 1.08rem;
        font-weight: 900;
        letter-spacing: -.03em;
    }

    .timeline-heading p {
        margin: 4px 0 0;
        color: #78849a;
        font-weight: 750;
        font-size: .84rem;
    }

    .timeline-list {
        position: relative;
        display: flex !important;
        flex-direction: column;
        gap: 14px;
        padding: 4px 0;
    }

    .timeline-list::before {
        content: '';
        position: absolute;
        left: 62px;
        top: 10px;
        bottom: 10px;
        width: 1px;
        background: #e4e9f2;
    }

    .timeline-row,
    .timeline-now-row {
        position: relative;
        display: grid !important;
        grid-template-columns: 54px minmax(0, 1fr);
        gap: 12px;
        align-items: start;
    }

    .timeline-row::before {
        content: '';
        position: absolute;
        left: 58px;
        top: 28px;
        width: 11px;
        height: 11px;
        border-radius: 50%;
        background: var(--priority-color, var(--agdm-orange));
        border: 3px solid #fff;
        box-shadow: 0 0 0 1px rgba(226, 232, 240, .9);
        z-index: 2;
    }

    .time-label {
        color: #687389;
        font-size: .9rem;
        font-weight: 850;
        padding-top: 20px;
        font-variant-numeric: tabular-nums;
    }

    .timeline-event-card {
        position: relative;
        min-height: unset;
        display: grid !important;
        grid-template-columns: 44px minmax(0, 1fr);
        gap: 12px;
        border: 1px solid rgba(226, 232, 240, .9);
        border-radius: 22px;
        padding: 15px 12px 14px 16px;
        background: #fff;
        box-shadow: 0 14px 32px rgba(15, 23, 42, .065);
        overflow: hidden;
    }

    .timeline-event-card::before {
        content: '';
        position: absolute;
        inset: 0 auto 0 0;
        width: 5px;
        background: var(--priority-color, var(--agdm-orange));
    }

    .timeline-event-card.status-concluido { opacity: .74; }

    .event-icon {
        width: 44px;
        height: 44px;
        display: grid !important;
        place-items: center;
        border-radius: 16px;
        color: var(--agdm-primary);
        background: #eef2ff;
        font-size: 1rem;
    }

    .event-icon.category-trabalho { color: #2454d6; background: #eef2ff; }
    .event-icon.category-pessoal { color: #7c3aed; background: #f3e8ff; }
    .event-icon.category-estudos { color: #ca8a04; background: #fef9c3; }
    .event-icon.category-outros { color: #0891b2; background: #cffafe; }

    .event-title-line {
        display: flex !important;
        flex-direction: column;
        gap: 7px;
        align-items: flex-start;
    }

    .event-title-line h3 {
        margin: 0;
        color: #0e1933;
        font-size: 1rem;
        line-height: 1.2;
        font-weight: 900;
        letter-spacing: -.03em;
    }

    .event-status {
        width: fit-content;
        border-radius: 999px;
        padding: 5px 8px;
        font-size: .64rem;
        line-height: 1;
        font-weight: 900;
    }

    .event-status.pendente { color: #075985; background: #e0f2fe; }
    .event-status.concluido { color: #166534; background: #dcfce7; }

    .event-meta-line {
        display: flex !important;
        flex-wrap: wrap;
        gap: 8px 11px;
        margin: 10px 0 0;
        color: #697389;
        font-size: .78rem;
        font-weight: 760;
    }

    .event-meta-line i {
        margin-right: 5px;
        color: var(--priority-color, var(--agdm-primary));
    }

    .event-content p {
        margin: 9px 0 0;
        color: #5e697f;
        font-size: .84rem;
        line-height: 1.45;
    }

    /* no mobile, a tela principal fica limpa; ações ficam no detalhe do compromisso */
    .event-actions-row {
        display: none !important;
    }

    .timeline-event-card::after {
        content: 'Toque para abrir';
        display: block;
        grid-column: 2;
        width: fit-content;
        margin-top: 9px;
        border-radius: 999px;
        padding: 6px 10px;
        color: var(--agdm-primary);
        background: #eef2ff;
        font-size: .72rem;
        font-weight: 900;
    }

    .timeline-now-row {
        align-items: center;
        min-height: 28px;
    }

    .timeline-now-row .time-label.now {
        padding: 0;
        color: var(--agdm-primary);
        font-weight: 950;
    }

    .now-dot {
        position: absolute;
        left: 57px;
        width: 13px;
        height: 13px;
        border-radius: 50%;
        background: var(--agdm-primary);
        border: 3px solid #fff;
        z-index: 3;
    }

    .now-line {
        height: 3px;
        border-radius: 999px;
        background: linear-gradient(90deg, var(--agdm-primary), #6d5df7);
    }

    .available-slot {
        margin-left: 66px;
        min-height: 58px;
        display: grid !important;
        place-items: center;
        border: 2px dashed #d8deea;
        border-radius: 18px;
        color: #8a94a8 !important;
        background: rgba(255,255,255,.7);
        text-decoration: none !important;
        font-size: .88rem;
        font-weight: 900;
    }

    .available-slot.big-slot {
        margin-left: 0;
        min-height: 110px;
    }

    .available-slot i { margin-right: 8px; }

    .priority-alta { --priority-color: var(--agdm-red); }
    .priority-media { --priority-color: var(--agdm-orange); }
    .priority-baixa { --priority-color: var(--agdm-green); }

    .mobile-bottom-nav.app-mobile-nav {
        left: 8px;
        right: 8px;
        bottom: calc(12px + env(safe-area-inset-bottom));
        display: grid !important;
        grid-template-columns: 1fr 1fr 62px 1fr 1fr;
        align-items: center;
        gap: 4px;
        padding: 8px 7px;
        border: 1px solid rgba(226, 232, 240, .95);
        border-radius: 28px;
        background: rgba(255,255,255,.97);
        box-shadow: 0 24px 60px rgba(15, 23, 42, .18);
        backdrop-filter: blur(16px);
    }

    .app-mobile-nav .bottom-nav-item {
        min-height: 48px;
        border-radius: 18px;
        color: #64748b !important;
        text-decoration: none !important;
        font-size: .62rem;
        font-weight: 850;
    }

    .app-mobile-nav .bottom-nav-item.active:not(.bottom-nav-create) {
        background: #eef2ff;
        color: var(--agdm-primary) !important;
    }

    .app-mobile-nav .bottom-nav-create {
        width: 56px;
        height: 56px;
        min-height: 56px;
        margin: -24px auto 0;
        border-radius: 999px;
        color: #fff !important;
        background: linear-gradient(135deg, #2454d6, #5735e8);
        box-shadow: 0 18px 34px rgba(37, 84, 214, .34);
    }

    .app-mobile-nav .bottom-nav-create i { font-size: 1.2rem; }
    .app-mobile-nav .bottom-nav-create span { display: none; }
}

@media (max-width: 380px) {
    .daily-date-block h1 { font-size: 1.55rem; }
    .day-strip { grid-auto-columns: 64px; gap: 8px; }
    .daily-summary-strip span { font-size: .58rem; }
    .timeline-event-card { grid-template-columns: 1fr; }
    .event-icon { display: none !important; }
    .timeline-event-card::after { grid-column: 1; }
}

/* Agendamobily v4.5.2 - refinamento visual da home diaria mobile */
@media (max-width: 991.98px) {
    .content-wrapper,
    body.sidebar-collapsed .content-wrapper,
    body.sidebar-expanded .content-wrapper {
        padding-left: 16px !important;
        padding-right: 16px !important;
        padding-bottom: calc(156px + env(safe-area-inset-bottom)) !important;
    }

    .daily-app-screen {
        padding-bottom: 104px;
    }

    .daily-app-header {
        margin-bottom: 20px;
    }

    .daily-date-block h1 {
        font-size: clamp(1.9rem, 7.6vw, 2.35rem);
        letter-spacing: -.065em;
    }

    .day-strip {
        grid-auto-columns: minmax(72px, 1fr);
        gap: 12px;
        padding-bottom: 18px;
    }

    .daily-summary-strip {
        gap: 10px;
        margin-bottom: 16px;
    }

    .daily-summary-strip div {
        min-height: 70px;
        border-radius: 20px;
        background: rgba(255,255,255,.96);
    }

    .next-focus-card {
        margin-bottom: 20px;
        padding: 17px 14px 17px 20px;
        border-radius: 24px;
    }

    .next-focus-card a {
        width: 48px;
        height: 48px;
        padding: 0;
        display: grid;
        place-items: center;
        font-size: 0;
    }

    .next-focus-card a::after {
        content: 'Ver';
        font-size: .86rem;
    }

    .timeline-panel {
        border: 0 !important;
        box-shadow: none !important;
        background: transparent !important;
        padding: 0 !important;
        margin-top: 12px;
        border-radius: 0 !important;
    }

    .timeline-heading {
        margin-bottom: 16px;
        padding: 0 2px;
    }

    .timeline-heading h2 {
        font-size: 1.22rem;
    }

    .timeline-heading .btn {
        display: none !important;
    }

    .timeline-list {
        gap: 18px;
        padding-bottom: 98px;
    }

    .timeline-list::before {
        left: 62px;
        top: 8px;
        bottom: 94px;
        background: linear-gradient(180deg, #dbe3ef, #edf1f7);
    }

    .timeline-row,
    .timeline-now-row {
        grid-template-columns: 58px minmax(0, 1fr);
        gap: 14px;
    }

    .timeline-row::before {
        left: 58px;
        top: 30px;
        width: 13px;
        height: 13px;
        border-width: 3px;
    }

    .time-label {
        padding-top: 24px;
        font-size: .96rem;
        color: #64718a;
    }

    .timeline-event-card {
        min-height: 160px;
        grid-template-columns: 52px minmax(0, 1fr);
        gap: 14px;
        padding: 18px 15px 17px 18px;
        border-radius: 24px;
        background: rgba(255,255,255,.98);
        box-shadow: 0 18px 42px rgba(15, 23, 42, .07);
    }

    .timeline-event-card::before {
        width: 5px;
    }

    .event-icon {
        width: 52px;
        height: 52px;
        border-radius: 18px;
        font-size: 1.08rem;
    }

    .event-title-line h3 {
        font-size: 1.04rem;
        line-height: 1.18;
    }

    .event-status {
        padding: 5px 9px;
        font-size: .62rem;
    }

    .event-meta-line {
        gap: 8px 12px;
        margin-top: 11px;
        font-size: .78rem;
    }

    .event-content p {
        margin-top: 10px;
        font-size: .88rem;
        color: #68748a;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .timeline-event-card::after {
        content: '';
        display: none !important;
    }

    .timeline-event-card:active {
        transform: scale(.992);
    }

    .timeline-now-row {
        min-height: 34px;
    }

    .now-dot {
        left: 58px;
        width: 14px;
        height: 14px;
    }

    .now-line {
        align-self: center;
        height: 3px;
        box-shadow: 0 6px 18px rgba(79,70,229,.22);
    }

    .available-slot {
        margin-left: 72px;
        min-height: 64px;
        border-radius: 20px;
        background: rgba(255,255,255,.72);
    }

    .monthly-section,
    .support-section {
        margin-bottom: 104px;
    }

    .support-section {
        display: none !important;
    }

    .mobile-bottom-nav.app-mobile-nav {
        left: 12px;
        right: 12px;
        bottom: calc(12px + env(safe-area-inset-bottom));
        border-radius: 30px;
        padding: 9px 8px;
    }
}

@media (max-width: 430px) {
    .content-wrapper,
    body.sidebar-collapsed .content-wrapper,
    body.sidebar-expanded .content-wrapper {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    .timeline-row,
    .timeline-now-row {
        grid-template-columns: 54px minmax(0, 1fr);
        gap: 12px;
    }

    .timeline-list::before { left: 58px; }
    .timeline-row::before { left: 54px; }
    .now-dot { left: 54px; }
    .available-slot { margin-left: 66px; }

    .timeline-event-card {
        grid-template-columns: 48px minmax(0, 1fr);
        gap: 12px;
        padding: 17px 13px 16px 16px;
    }

    .event-icon {
        width: 48px;
        height: 48px;
    }
}


/* v4.5.3 - refinamento visual da tela Hoje: modo app diário */
@media (max-width: 767.98px) {
    body.agenda-layout {
        background:
            radial-gradient(circle at 80% 0%, rgba(91, 53, 238, .09), transparent 30%),
            linear-gradient(180deg, #ffffff 0%, #f7f9fd 48%, #ffffff 100%) !important;
    }

    .topbar {
        display: none !important;
    }

    .content-wrapper,
    main.content-wrapper,
    .app-main {
        padding-top: calc(12px + env(safe-area-inset-top)) !important;
    }

    .daily-app-screen {
        max-width: 430px;
        margin: 0 auto;
        padding-inline: 2px;
    }

    .daily-app-header {
        margin-bottom: 18px;
    }

    .daily-date-block::before {
        content: '\f073';
        font-family: 'Font Awesome 6 Free';
        font-weight: 900;
        display: grid;
        place-items: center;
        width: 42px;
        height: 42px;
        margin-bottom: 28px;
        border-radius: 15px;
        color: #4b36e8;
        background: #f1f0ff;
        box-shadow: 0 12px 28px rgba(79, 70, 229, .12);
    }

    .daily-kicker {
        color: #7c8498;
        font-size: 1.02rem;
        text-transform: none;
        letter-spacing: 0;
        font-weight: 800;
    }

    .daily-date-block h1 {
        margin-top: 2px;
        font-size: 2.38rem;
        line-height: .98;
        letter-spacing: -.06em;
        color: #0a1533;
    }

    .daily-action-button {
        width: 50px;
        height: 50px;
        border-radius: 20px;
        color: #4b36e8;
        background: rgba(255, 255, 255, .86);
        box-shadow: 0 16px 42px rgba(15, 23, 42, .08);
    }

    .day-strip {
        grid-auto-columns: 76px;
        gap: 14px;
        padding: 2px 0 20px;
        margin-inline: -1px;
    }

    .day-chip {
        min-height: 86px;
        border-radius: 22px;
        border-color: #e5eaf3;
        box-shadow: 0 12px 25px rgba(15, 23, 42, .045);
    }

    .day-chip span { font-size: .88rem; }
    .day-chip strong { font-size: 1.6rem; }

    .day-chip.active {
        background: linear-gradient(145deg, #2454d6 0%, #5938ee 72%, #6d5df7 100%) !important;
        transform: translateY(-2px);
    }

    .daily-summary-strip {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 9px;
        margin-bottom: 18px;
    }

    .daily-summary-strip div {
        min-height: 72px;
        border-radius: 22px;
        background: rgba(255, 255, 255, .72);
        backdrop-filter: blur(16px);
    }

    .daily-summary-strip strong { font-size: 1.38rem; }
    .daily-summary-strip span { font-size: .66rem; }

    .next-focus-card {
        margin-bottom: 22px;
        border-radius: 24px;
        padding: 18px 16px 18px 21px;
        background: rgba(255, 255, 255, .88);
        box-shadow: 0 18px 40px rgba(15, 23, 42, .075);
    }

    .next-focus-card span { font-size: .82rem; }
    .next-focus-card strong { font-size: 1.08rem; }
    .next-focus-card small { font-size: .8rem; }

    .next-focus-card a {
        width: 44px;
        height: 44px;
        display: grid !important;
        place-items: center;
        padding: 0;
        border-radius: 17px;
    }

    .timeline-panel,
    .timeline-panel.agenda-card {
        margin-top: 0;
        padding: 0 !important;
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
        border-radius: 0 !important;
    }

    .timeline-heading {
        margin-bottom: 18px;
        padding: 0 1px;
    }

    .timeline-heading h2 {
        font-size: 1.22rem;
        color: #0c1733;
        letter-spacing: -.045em;
    }

    .timeline-heading p {
        font-size: .88rem;
        color: #7a8396;
    }

    .timeline-heading .btn {
        display: none !important;
    }

    .timeline-list {
        gap: 26px;
        padding-bottom: 132px;
    }

    .timeline-list::before {
        left: 72px;
        top: 16px;
        bottom: 92px;
        width: 2px;
        background: linear-gradient(180deg, #e8edf6, #dfe6f0 60%, transparent);
    }

    .timeline-row,
    .timeline-now-row {
        grid-template-columns: 64px minmax(0, 1fr);
        gap: 18px;
    }

    .timeline-row::before {
        left: 67px;
        top: 38px;
        width: 13px;
        height: 13px;
        border-width: 3px;
        background: var(--priority-color, #f59e0b);
    }

    .time-label {
        padding-top: 31px;
        color: #667085;
        font-size: 1.01rem;
        font-weight: 900;
    }

    .timeline-event-card {
        grid-template-columns: 54px minmax(0, 1fr);
        gap: 16px;
        min-height: 136px;
        padding: 22px 18px 20px 22px;
        border-radius: 26px;
        border-color: #e3e9f2;
        background: rgba(255, 255, 255, .88);
        box-shadow: 0 20px 48px rgba(15, 23, 42, .08);
        cursor: pointer;
        transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
        -webkit-tap-highlight-color: transparent;
    }

    .timeline-event-card:active {
        transform: scale(.985);
        box-shadow: 0 12px 28px rgba(15, 23, 42, .075);
    }

    .timeline-event-card::before {
        width: 5px;
        border-radius: 999px;
    }

    .timeline-event-card::after {
        content: none !important;
        display: none !important;
    }

    .event-icon {
        width: 54px;
        height: 54px;
        border-radius: 19px;
        font-size: 1.12rem;
    }

    .event-title-line {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: start;
        gap: 10px;
    }

    .event-title-line h3 {
        font-size: 1.1rem;
        line-height: 1.2;
    }

    .event-status {
        padding: 6px 9px;
        font-size: .66rem;
        white-space: nowrap;
    }

    .event-meta-line {
        gap: 9px 14px;
        margin-top: 13px;
        font-size: .83rem;
        font-weight: 850;
    }

    .event-content p {
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
        margin-top: 12px;
        color: #6b7487;
        font-size: .9rem;
    }

    .timeline-now-row {
        min-height: 34px;
        align-items: center;
    }

    .timeline-now-row .time-label.now {
        color: #4b36e8;
        font-size: 1.02rem;
        font-weight: 950;
    }

    .now-dot {
        left: 66px;
        width: 14px;
        height: 14px;
        background: #4b36e8;
    }

    .now-line {
        height: 3px;
        background: linear-gradient(90deg, #4b36e8 0%, #6d5df7 70%, transparent 100%);
    }

    .available-slot {
        margin-left: 82px;
        min-height: 76px;
        border-radius: 22px;
        color: #8b96aa !important;
        background: rgba(255, 255, 255, .55);
    }

    .available-slot.big-slot {
        margin-left: 82px;
        min-height: 92px;
    }

    .fab-mobile {
        display: none !important;
    }

    .agenda-detail-sheet {
        position: fixed;
        inset: 0;
        z-index: 2300;
        display: none;
    }

    .agenda-detail-sheet.is-open {
        display: block;
    }

    .agenda-detail-backdrop {
        position: absolute;
        inset: 0;
        background: rgba(8, 18, 43, .42);
        backdrop-filter: blur(8px);
    }

    .agenda-detail-panel {
        position: absolute;
        left: 10px;
        right: 10px;
        bottom: calc(10px + env(safe-area-inset-bottom));
        max-width: 430px;
        margin: 0 auto;
        border: 1px solid rgba(226, 232, 240, .9);
        border-radius: 30px;
        padding: 24px 18px 18px;
        background: rgba(255, 255, 255, .96);
        box-shadow: 0 -24px 80px rgba(15, 23, 42, .24);
        animation: agendaSheetIn .22s ease-out;
    }

    @keyframes agendaSheetIn {
        from { transform: translateY(18px); opacity: 0; }
        to { transform: translateY(0); opacity: 1; }
    }

    .agenda-detail-close {
        position: absolute;
        top: 14px;
        right: 14px;
        width: 38px;
        height: 38px;
        display: grid;
        place-items: center;
        border: 0;
        border-radius: 15px;
        color: #667085;
        background: #f3f5f9;
    }

    .detail-priority-badge {
        display: inline-flex;
        align-items: center;
        gap: 7px;
        max-width: calc(100% - 52px);
        border-radius: 999px;
        padding: 8px 12px;
        color: #9a3412;
        background: #fff7ed;
        font-size: .78rem;
        font-weight: 900;
    }

    .detail-priority-badge::before {
        content: '\f024';
        font-family: 'Font Awesome 6 Free';
        font-weight: 900;
    }

    .agenda-detail-panel h2 {
        margin: 14px 52px 6px 0;
        color: #0a1533;
        font-size: 1.48rem;
        line-height: 1.14;
        font-weight: 950;
        letter-spacing: -.045em;
    }

    .detail-description {
        min-height: 22px;
        margin: 0 0 16px;
        color: #596478;
        font-size: .94rem;
        line-height: 1.45;
    }

    .detail-info-grid {
        display: grid;
        gap: 10px;
        margin-bottom: 16px;
        padding: 14px;
        border-radius: 22px;
        background: #f8fafc;
    }

    .detail-info-grid div {
        display: flex;
        align-items: center;
        gap: 10px;
        color: #4b5565;
        font-size: .93rem;
        font-weight: 800;
    }

    .detail-info-grid i {
        width: 20px;
        text-align: center;
        color: #4b36e8;
    }

    .detail-actions-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .detail-actions-grid form {
        margin: 0;
    }

    .detail-action {
        min-height: 52px;
        width: 100%;
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        gap: 8px;
        border: 0;
        border-radius: 18px;
        font-weight: 900;
        text-decoration: none !important;
        color: #1f2a44 !important;
        background: #f3f5f9;
    }

    .detail-action.success { color: #166534 !important; background: #dcfce7; }
    .detail-action.warning { color: #92400e !important; background: #fef3c7; }
    .detail-action.whatsapp { color: #047857 !important; background: #d1fae5; }
    .detail-action.danger { color: #b91c1c !important; background: #fee2e2; }
}

@media (min-width: 768px) {
    .agenda-detail-sheet { display: none !important; }
}

/* v4.5.4 - topo mobile mais compacto para teste em celular real */
@media (max-width: 767.98px) {
    .daily-app-screen {
        padding-inline: 0;
    }

    .daily-app-header {
        margin-bottom: 12px;
        align-items: flex-start;
    }

    .daily-date-block::before {
        width: 36px;
        height: 36px;
        margin-bottom: 18px;
        border-radius: 13px;
        font-size: .92rem;
        box-shadow: 0 10px 22px rgba(79, 70, 229, .10);
    }

    .daily-kicker {
        font-size: .9rem;
        font-weight: 850;
    }

    .daily-date-block h1 {
        margin-top: 1px;
        font-size: 1.78rem;
        line-height: 1.03;
        letter-spacing: -.045em;
        max-width: 250px;
    }

    .daily-action-button {
        width: 44px;
        height: 44px;
        border-radius: 16px;
        font-size: .92rem;
        box-shadow: 0 12px 30px rgba(15, 23, 42, .075);
    }

    .daily-header-actions {
        gap: 8px;
        padding-top: 2px;
    }

    .day-strip {
        grid-auto-columns: 62px;
        gap: 10px;
        padding: 0 0 14px;
        margin-top: 2px;
    }

    .day-chip {
        min-height: 68px;
        border-radius: 18px;
        padding: 10px 8px;
        box-shadow: 0 10px 20px rgba(15, 23, 42, .035);
    }

    .day-chip span {
        font-size: .75rem;
        line-height: 1;
    }

    .day-chip strong {
        margin-top: 4px;
        font-size: 1.28rem;
        line-height: 1;
    }

    .day-chip.active {
        transform: translateY(-1px);
        box-shadow: 0 12px 28px rgba(79, 70, 229, .22);
    }

    .daily-summary-strip {
        gap: 8px;
        margin-bottom: 14px;
    }

    .daily-summary-strip div {
        min-height: 60px;
        border-radius: 18px;
        padding: 10px 4px;
    }

    .daily-summary-strip strong {
        font-size: 1.18rem;
        line-height: 1.05;
    }

    .daily-summary-strip span {
        margin-top: 3px;
        font-size: .62rem;
    }

    .next-focus-card {
        margin-bottom: 18px;
        border-radius: 22px;
        padding: 16px 14px 16px 18px;
        box-shadow: 0 14px 34px rgba(15, 23, 42, .065);
    }

    .next-focus-card span {
        font-size: .78rem;
    }

    .next-focus-card strong {
        font-size: 1rem;
        line-height: 1.18;
    }

    .next-focus-card small {
        font-size: .76rem;
    }

    .next-focus-card a {
        width: 40px;
        height: 40px;
        border-radius: 15px;
        font-size: .84rem;
    }

    .timeline-heading {
        margin-bottom: 14px;
    }

    .timeline-heading h2 {
        font-size: 1.12rem;
    }

    .timeline-heading p {
        font-size: .82rem;
    }

    .timeline-list {
        gap: 22px;
    }
}

@media (max-width: 390px) {
    .daily-date-block h1 {
        font-size: 1.64rem;
        max-width: 220px;
    }

    .day-strip {
        grid-auto-columns: 58px;
        gap: 8px;
    }

    .day-chip {
        min-height: 64px;
        border-radius: 17px;
    }

    .day-chip strong {
        font-size: 1.18rem;
    }
}

/* v4.5.5 - modo mobile mais compacto/premium para teste em celular real */
@media (max-width: 767.98px) {
    .content-wrapper,
    .content,
    .container-fluid {
        padding-top: 0 !important;
    }

    .agenda-mobile-app-shell,
    .daily-app-screen {
        padding-top: 12px !important;
    }

    .daily-app-header {
        margin-bottom: 8px !important;
    }

    .daily-date-block::before {
        width: 30px !important;
        height: 30px !important;
        margin-bottom: 12px !important;
        border-radius: 11px !important;
        font-size: .78rem !important;
    }

    .daily-kicker {
        font-size: .78rem !important;
        line-height: 1.05 !important;
        margin-bottom: 2px !important;
    }

    .daily-date-block h1 {
        font-size: 1.46rem !important;
        line-height: 1.01 !important;
        letter-spacing: -.05em !important;
        max-width: 205px !important;
    }

    .daily-header-actions {
        gap: 7px !important;
        padding-top: 4px !important;
    }

    .daily-action-button {
        width: 38px !important;
        height: 38px !important;
        border-radius: 14px !important;
        font-size: .82rem !important;
    }

    .day-strip {
        grid-auto-columns: 53px !important;
        gap: 8px !important;
        padding-bottom: 10px !important;
        margin-top: 0 !important;
    }

    .day-chip {
        min-height: 58px !important;
        border-radius: 16px !important;
        padding: 8px 6px !important;
    }

    .day-chip span {
        font-size: .66rem !important;
        font-weight: 850 !important;
    }

    .day-chip strong {
        margin-top: 3px !important;
        font-size: 1.05rem !important;
    }

    .daily-summary-strip {
        gap: 7px !important;
        margin-bottom: 12px !important;
    }

    .daily-summary-strip div {
        min-height: 50px !important;
        border-radius: 16px !important;
        padding: 7px 3px !important;
    }

    .daily-summary-strip strong {
        font-size: 1rem !important;
        line-height: 1 !important;
    }

    .daily-summary-strip span {
        margin-top: 2px !important;
        font-size: .55rem !important;
        line-height: 1.1 !important;
    }

    .next-focus-card {
        margin-bottom: 14px !important;
        border-radius: 20px !important;
        padding: 13px 12px 13px 16px !important;
        min-height: auto !important;
    }

    .next-focus-card span {
        font-size: .70rem !important;
    }

    .next-focus-card strong {
        font-size: .90rem !important;
        line-height: 1.12 !important;
    }

    .next-focus-card small {
        font-size: .68rem !important;
        line-height: 1.2 !important;
    }

    .next-focus-card a {
        width: 36px !important;
        height: 36px !important;
        border-radius: 13px !important;
        font-size: .76rem !important;
    }

    .timeline-heading {
        margin-bottom: 10px !important;
    }

    .timeline-heading h2 {
        font-size: 1rem !important;
        line-height: 1.1 !important;
    }

    .timeline-heading p {
        font-size: .72rem !important;
        margin-top: 2px !important;
    }

    .timeline-list {
        gap: 16px !important;
        padding-bottom: 96px !important;
    }

    .timeline-time {
        width: 54px !important;
        font-size: .82rem !important;
    }

    .timeline-item {
        gap: 10px !important;
    }

    .timeline-dot {
        width: 10px !important;
        height: 10px !important;
        margin-top: 22px !important;
    }

    .timeline-card {
        border-radius: 20px !important;
        padding: 14px 14px !important;
        min-height: 116px !important;
    }

    .timeline-card::before {
        width: 3px !important;
    }

    .event-icon {
        width: 42px !important;
        height: 42px !important;
        border-radius: 15px !important;
        font-size: .94rem !important;
    }

    .event-card-head {
        gap: 10px !important;
        margin-bottom: 8px !important;
    }

    .event-card-title {
        font-size: .95rem !important;
        line-height: 1.08 !important;
    }

    .event-status-chip {
        padding: 4px 8px !important;
        border-radius: 999px !important;
        font-size: .58rem !important;
    }

    .event-meta-line,
    .event-description-preview,
    .event-reminder-line {
        font-size: .72rem !important;
        line-height: 1.25 !important;
    }

    .event-description-preview {
        margin-top: 7px !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
    }

    .mobile-bottom-nav {
        left: 14px !important;
        right: 14px !important;
        bottom: 8px !important;
        height: 64px !important;
        border-radius: 24px !important;
        padding: 6px 10px !important;
    }

    .mobile-bottom-nav a {
        font-size: .58rem !important;
        gap: 2px !important;
    }

    .mobile-bottom-nav a i {
        font-size: .92rem !important;
    }

    .mobile-bottom-nav .nav-plus {
        width: 52px !important;
        height: 52px !important;
        margin-top: -22px !important;
        font-size: 1.35rem !important;
    }
}

@media (max-width: 390px) {
    .daily-date-block h1 {
        font-size: 1.34rem !important;
        max-width: 190px !important;
    }

    .day-strip {
        grid-auto-columns: 50px !important;
        gap: 7px !important;
    }

    .day-chip {
        min-height: 54px !important;
        border-radius: 15px !important;
    }

    .day-chip strong {
        font-size: .98rem !important;
    }

    .timeline-time {
        width: 48px !important;
        font-size: .78rem !important;
    }

    .timeline-card {
        padding: 13px 12px !important;
    }

    .event-card-title {
        font-size: .90rem !important;
    }
}


/* v4.5.7 - modo compacto final para celular real
   - elementos aproximados ao mockup aprovado;
   - barra vertical/dot/ícones seguem a cor da prioridade. */
@media (max-width: 767.98px) {
    :root {
        --priority-high: #ef4444;
        --priority-medium: #f59e0b;
        --priority-low: #10b981;
    }

    body.agenda-layout {
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 56%, #ffffff 100%) !important;
    }

    .content-wrapper,
    body.sidebar-collapsed .content-wrapper,
    body.sidebar-expanded .content-wrapper,
    main.content-wrapper,
    .app-main {
        padding: calc(8px + env(safe-area-inset-top)) 14px calc(86px + env(safe-area-inset-bottom)) !important;
    }

    .daily-app-screen {
        max-width: 430px;
        padding: 0 0 76px !important;
    }

    .daily-app-header {
        margin-bottom: 10px !important;
        gap: 10px !important;
    }

    .daily-date-block::before {
        display: none !important;
        content: none !important;
    }

    .daily-kicker {
        color: #7e8798 !important;
        font-size: .72rem !important;
        line-height: 1 !important;
        font-weight: 750 !important;
        margin-bottom: 4px !important;
    }

    .daily-date-block h1 {
        max-width: none !important;
        font-size: 1.18rem !important;
        line-height: 1.08 !important;
        letter-spacing: -.025em !important;
        font-weight: 900 !important;
        white-space: nowrap;
    }

    .daily-header-actions {
        gap: 7px !important;
        padding-top: 0 !important;
    }

    .daily-action-button {
        width: 34px !important;
        height: 34px !important;
        border-radius: 14px !important;
        font-size: .78rem !important;
        box-shadow: 0 10px 22px rgba(15,23,42,.055) !important;
    }

    .daily-alert-dot {
        min-width: 16px !important;
        height: 16px !important;
        font-size: .55rem !important;
        top: -5px !important;
        right: -5px !important;
    }

    .day-strip {
        grid-auto-columns: 54px !important;
        gap: 11px !important;
        padding: 2px 0 12px !important;
        margin: 0 -1px !important;
    }

    .day-chip {
        min-height: 56px !important;
        border-radius: 16px !important;
        padding: 7px 5px !important;
        box-shadow: 0 8px 18px rgba(15,23,42,.035) !important;
    }

    .day-chip span {
        font-size: .64rem !important;
        line-height: 1 !important;
        font-weight: 750 !important;
    }

    .day-chip strong {
        margin-top: 3px !important;
        font-size: 1.02rem !important;
        letter-spacing: -.02em !important;
    }

    .day-chip.active {
        transform: translateY(-1px) !important;
        border-radius: 17px !important;
        box-shadow: 0 12px 24px rgba(79,70,229,.24) !important;
    }

    .daily-summary-strip {
        gap: 7px !important;
        margin-bottom: 11px !important;
    }

    .daily-summary-strip div {
        min-height: 46px !important;
        border-radius: 15px !important;
        padding: 6px 2px !important;
        box-shadow: 0 8px 18px rgba(15,23,42,.035) !important;
    }

    .daily-summary-strip strong {
        font-size: .96rem !important;
        line-height: 1 !important;
    }

    .daily-summary-strip span {
        font-size: .51rem !important;
        line-height: 1.1 !important;
        margin-top: 1px !important;
    }

    .next-focus-card {
        margin-bottom: 13px !important;
        padding: 12px 11px 12px 15px !important;
        border-radius: 18px !important;
        box-shadow: 0 12px 28px rgba(15,23,42,.055) !important;
    }

    .next-focus-card::before {
        width: 4px !important;
        background: var(--priority-color, var(--priority-medium)) !important;
    }

    .next-focus-card span {
        font-size: .66rem !important;
        line-height: 1.1 !important;
    }

    .next-focus-card strong {
        font-size: .86rem !important;
        line-height: 1.13 !important;
        margin: 2px 0 !important;
    }

    .next-focus-card small {
        font-size: .64rem !important;
        line-height: 1.15 !important;
    }

    .next-focus-card a {
        width: 34px !important;
        height: 34px !important;
        border-radius: 13px !important;
    }

    .next-focus-card a::after {
        font-size: .72rem !important;
    }

    .timeline-panel,
    .timeline-panel.agenda-card {
        margin-top: 2px !important;
        padding: 0 !important;
    }

    .timeline-heading {
        margin-bottom: 9px !important;
        padding: 0 !important;
    }

    .timeline-heading h2 {
        font-size: .98rem !important;
        line-height: 1.08 !important;
        letter-spacing: -.025em !important;
    }

    .timeline-heading p {
        margin-top: 2px !important;
        font-size: .70rem !important;
        line-height: 1.15 !important;
    }

    .timeline-list {
        gap: 14px !important;
        padding: 2px 0 92px !important;
    }

    .timeline-list::before {
        left: 57px !important;
        top: 11px !important;
        bottom: 74px !important;
        width: 1px !important;
        background: #dfe6f0 !important;
    }

    .timeline-row,
    .timeline-now-row {
        grid-template-columns: 48px minmax(0, 1fr) !important;
        gap: 11px !important;
    }

    .timeline-row::before {
        left: 53px !important;
        top: 26px !important;
        width: 10px !important;
        height: 10px !important;
        border-width: 2px !important;
        background: var(--priority-color, var(--priority-medium)) !important;
    }

    .time-label,
    .timeline-now-row .time-label.now {
        padding-top: 22px !important;
        font-size: .80rem !important;
        line-height: 1 !important;
        font-weight: 800 !important;
    }

    .timeline-now-row {
        min-height: 24px !important;
    }

    .timeline-now-row .time-label.now {
        padding-top: 0 !important;
    }

    .now-dot {
        left: 52px !important;
        width: 10px !important;
        height: 10px !important;
        border-width: 2px !important;
    }

    .now-line {
        height: 2px !important;
    }

    .timeline-event-card {
        grid-template-columns: 38px minmax(0, 1fr) !important;
        gap: 10px !important;
        min-height: 104px !important;
        padding: 13px 12px 12px 14px !important;
        border-radius: 18px !important;
        box-shadow: 0 12px 28px rgba(15,23,42,.055) !important;
        border-color: #e5eaf3 !important;
        background: rgba(255,255,255,.94) !important;
    }

    .timeline-event-card::before {
        width: 4px !important;
        border-radius: 99px !important;
        background: var(--priority-color, var(--priority-medium)) !important;
    }

    .event-icon {
        width: 38px !important;
        height: 38px !important;
        border-radius: 14px !important;
        font-size: .82rem !important;
        color: var(--priority-color, var(--priority-medium)) !important;
        background: color-mix(in srgb, var(--priority-color, var(--priority-medium)) 13%, white) !important;
    }

    .event-title-line {
        grid-template-columns: minmax(0, 1fr) auto !important;
        gap: 7px !important;
    }

    .event-title-line h3 {
        font-size: .88rem !important;
        line-height: 1.12 !important;
        letter-spacing: -.015em !important;
    }

    .event-status {
        padding: 4px 7px !important;
        font-size: .54rem !important;
    }

    .event-meta-line {
        gap: 5px 9px !important;
        margin-top: 8px !important;
        font-size: .66rem !important;
        line-height: 1.15 !important;
        font-weight: 750 !important;
    }

    .event-meta-line i {
        margin-right: 4px !important;
        color: var(--priority-color, var(--priority-medium)) !important;
    }

    .event-content p {
        margin-top: 8px !important;
        font-size: .72rem !important;
        line-height: 1.28 !important;
        color: #657189 !important;
        -webkit-line-clamp: 2 !important;
    }

    .available-slot {
        margin-left: 59px !important;
        min-height: 44px !important;
        border-radius: 15px !important;
        font-size: .72rem !important;
        border-width: 1.5px !important;
    }

    .available-slot.big-slot {
        margin-left: 59px !important;
        min-height: 60px !important;
    }

    .mobile-bottom-nav.app-mobile-nav,
    .mobile-bottom-nav {
        left: 14px !important;
        right: 14px !important;
        bottom: calc(7px + env(safe-area-inset-bottom)) !important;
        min-height: 60px !important;
        height: 60px !important;
        border-radius: 24px !important;
        padding: 6px 8px !important;
        grid-template-columns: 1fr 1fr 54px 1fr 1fr !important;
        box-shadow: 0 18px 42px rgba(15,23,42,.16) !important;
    }

    .app-mobile-nav .bottom-nav-item,
    .mobile-bottom-nav a {
        min-height: 42px !important;
        font-size: .55rem !important;
        gap: 2px !important;
        border-radius: 15px !important;
    }

    .app-mobile-nav .bottom-nav-item i,
    .mobile-bottom-nav a i {
        font-size: .86rem !important;
    }

    .app-mobile-nav .bottom-nav-create,
    .mobile-bottom-nav .nav-plus {
        width: 50px !important;
        height: 50px !important;
        min-height: 50px !important;
        margin: -20px auto 0 !important;
        font-size: 1.20rem !important;
    }

    .priority-alta {
        --priority-color: var(--priority-high) !important;
    }

    .priority-media {
        --priority-color: var(--priority-medium) !important;
    }

    .priority-baixa {
        --priority-color: var(--priority-low) !important;
    }
}

@media (max-width: 390px) {
    .daily-date-block h1 {
        font-size: 1.08rem !important;
    }

    .day-strip {
        grid-auto-columns: 50px !important;
        gap: 8px !important;
    }

    .day-chip {
        min-height: 52px !important;
    }

    .timeline-row,
    .timeline-now-row {
        grid-template-columns: 44px minmax(0, 1fr) !important;
        gap: 10px !important;
    }

    .timeline-list::before { left: 52px !important; }
    .timeline-row::before { left: 48px !important; }
    .now-dot { left: 47px !important; }
    .available-slot { margin-left: 54px !important; }

    .timeline-event-card {
        grid-template-columns: 34px minmax(0, 1fr) !important;
        gap: 9px !important;
        padding: 12px 10px 11px 13px !important;
        min-height: 98px !important;
    }

    .event-icon {
        width: 34px !important;
        height: 34px !important;
        border-radius: 12px !important;
    }
}

/* v4.5.8 - hotfix PDO + ajuste final de escala mobile */
@media (max-width: 767.98px) {
    .daily-date-block h1 {
        font-size: 1.12rem !important;
        line-height: 1.05 !important;
    }

    .daily-kicker {
        font-size: .68rem !important;
    }

    .day-strip {
        grid-auto-columns: 51px !important;
        gap: 9px !important;
        padding-bottom: 10px !important;
    }

    .day-chip {
        min-height: 53px !important;
        border-radius: 15px !important;
    }

    .day-chip strong {
        font-size: .96rem !important;
    }

    .daily-summary-strip div {
        min-height: 43px !important;
        border-radius: 14px !important;
    }

    .daily-summary-strip strong {
        font-size: .90rem !important;
    }

    .daily-summary-strip span {
        font-size: .49rem !important;
    }

    .next-focus-card {
        padding: 11px 10px 11px 14px !important;
        border-radius: 17px !important;
    }

    .timeline-event-card {
        min-height: 96px !important;
        border-radius: 17px !important;
        padding: 12px 11px 11px 13px !important;
    }

    .timeline-event-card::before,
    .next-focus-card::before {
        background: var(--priority-color, var(--priority-medium)) !important;
    }

    .event-icon {
        width: 35px !important;
        height: 35px !important;
        border-radius: 13px !important;
        color: var(--priority-color, var(--priority-medium)) !important;
    }

    .event-title-line h3 {
        font-size: .84rem !important;
    }

    .event-meta-line {
        font-size: .63rem !important;
    }

    .event-content p {
        font-size: .69rem !important;
    }
}

/* v4.5.9 - ajuste fino final conforme referencia compacta aprovada
   - proporcao dos elementos semelhante ao modelo validado pelo usuario;
   - barra vertical, dot da timeline, icone e realces sempre pela prioridade;
   - mais area livre para a linha do tempo no celular real. */
@media (max-width: 767.98px) {
    :root {
        --priority-high: #ef4444;
        --priority-medium: #f59e0b;
        --priority-low: #10b981;
        --priority-high-soft: #fff1f2;
        --priority-medium-soft: #fff7ed;
        --priority-low-soft: #ecfdf5;
        --today-primary: #5145ee;
        --today-primary-soft: #eef2ff;
    }

    body.agenda-layout {
        background: #ffffff !important;
    }

    .content-wrapper,
    body.sidebar-collapsed .content-wrapper,
    body.sidebar-expanded .content-wrapper,
    main.content-wrapper,
    .app-main {
        padding: calc(8px + env(safe-area-inset-top)) 16px calc(84px + env(safe-area-inset-bottom)) !important;
        background: #ffffff !important;
    }

    .daily-app-screen {
        max-width: 424px !important;
        margin: 0 auto !important;
        padding: 0 0 68px !important;
    }

    .daily-app-header {
        align-items: flex-start !important;
        margin: 0 0 12px !important;
        gap: 10px !important;
    }

    .daily-date-block::before {
        display: none !important;
        content: none !important;
    }

    .daily-kicker {
        color: #8a94a6 !important;
        font-size: .72rem !important;
        line-height: 1 !important;
        font-weight: 700 !important;
        margin: 0 0 5px !important;
    }

    .daily-date-block h1 {
        max-width: none !important;
        margin: 0 !important;
        color: #07132d !important;
        font-size: 1.20rem !important;
        line-height: 1.05 !important;
        letter-spacing: -.025em !important;
        font-weight: 900 !important;
        white-space: nowrap !important;
    }

    .daily-header-actions {
        gap: 8px !important;
        padding-top: 0 !important;
    }

    .daily-action-button {
        width: 34px !important;
        height: 34px !important;
        border-radius: 999px !important;
        border-color: transparent !important;
        color: var(--today-primary) !important;
        background: #f3f4f8 !important;
        box-shadow: none !important;
        font-size: .78rem !important;
    }

    .day-strip {
        grid-auto-columns: 54px !important;
        gap: 14px !important;
        padding: 3px 0 18px !important;
        margin: 0 -1px !important;
    }

    .day-chip {
        min-height: 56px !important;
        padding: 7px 6px !important;
        border-radius: 14px !important;
        border: 1px solid #edf0f6 !important;
        color: #8b94a8 !important;
        background: #ffffff !important;
        box-shadow: 0 6px 16px rgba(15,23,42,.035) !important;
    }

    .day-chip span {
        font-size: .66rem !important;
        line-height: 1 !important;
        font-weight: 700 !important;
    }

    .day-chip strong {
        margin-top: 4px !important;
        color: #111c35 !important;
        font-size: 1.02rem !important;
        line-height: 1 !important;
        letter-spacing: -.02em !important;
        font-weight: 900 !important;
    }

    .day-chip.active {
        color: #ffffff !important;
        border-color: transparent !important;
        background: linear-gradient(145deg, #5145ee, #4f46e5) !important;
        box-shadow: 0 12px 24px rgba(79,70,229,.24) !important;
        transform: translateY(-1px) !important;
    }

    .day-chip.active strong,
    .day-chip.active span {
        color: #ffffff !important;
    }

    .daily-summary-strip {
        display: none !important;
    }

    .next-focus-card {
        margin: 0 0 16px !important;
        padding: 12px 12px 12px 16px !important;
        border-radius: 16px !important;
        border: 1px solid #edf0f6 !important;
        background: #ffffff !important;
        box-shadow: 0 10px 24px rgba(15,23,42,.045) !important;
    }

    .next-focus-card::before {
        width: 4px !important;
        background: var(--priority-color, var(--priority-medium)) !important;
        border-radius: 999px !important;
    }

    .next-focus-card span {
        color: #7c8799 !important;
        font-size: .68rem !important;
        font-weight: 800 !important;
        line-height: 1.1 !important;
    }

    .next-focus-card strong {
        color: #0b1733 !important;
        font-size: .90rem !important;
        line-height: 1.14 !important;
        margin: 3px 0 !important;
    }

    .next-focus-card small {
        color: #6f7a8d !important;
        font-size: .66rem !important;
        line-height: 1.2 !important;
        font-weight: 750 !important;
    }

    .next-focus-card a {
        width: 34px !important;
        height: 34px !important;
        border-radius: 999px !important;
        color: var(--today-primary) !important;
        background: var(--today-primary-soft) !important;
    }

    .next-focus-card a::after {
        content: 'Ver' !important;
        font-size: .72rem !important;
    }

    .timeline-panel,
    .timeline-panel.agenda-card {
        margin-top: 0 !important;
        padding: 0 !important;
        background: transparent !important;
        border: 0 !important;
        border-radius: 0 !important;
        box-shadow: none !important;
    }

    .timeline-heading {
        margin: 0 0 10px !important;
        padding: 0 !important;
    }

    .timeline-heading h2 {
        color: #0b1733 !important;
        font-size: .98rem !important;
        line-height: 1.08 !important;
        letter-spacing: -.025em !important;
        font-weight: 900 !important;
    }

    .timeline-heading p {
        margin-top: 3px !important;
        color: #7c8799 !important;
        font-size: .70rem !important;
        line-height: 1.1 !important;
        font-weight: 750 !important;
    }

    .timeline-list {
        gap: 15px !important;
        padding: 2px 0 90px !important;
    }

    .timeline-list::before {
        left: 58px !important;
        top: 12px !important;
        bottom: 74px !important;
        width: 1px !important;
        background: #e2e8f0 !important;
    }

    .timeline-row,
    .timeline-now-row {
        grid-template-columns: 48px minmax(0, 1fr) !important;
        gap: 12px !important;
        align-items: start !important;
    }

    .timeline-row::before {
        left: 53px !important;
        top: 25px !important;
        width: 10px !important;
        height: 10px !important;
        border: 2px solid #ffffff !important;
        background: var(--priority-color, var(--priority-medium)) !important;
        box-shadow: 0 0 0 1px #e2e8f0 !important;
    }

    .time-label {
        padding-top: 21px !important;
        color: #667085 !important;
        font-size: .80rem !important;
        line-height: 1 !important;
        font-weight: 800 !important;
        letter-spacing: -.01em !important;
    }

    .timeline-event-card {
        grid-template-columns: 38px minmax(0, 1fr) !important;
        gap: 10px !important;
        min-height: 96px !important;
        padding: 12px 12px 11px 14px !important;
        border-radius: 16px !important;
        border: 1px solid #edf0f6 !important;
        background: #ffffff !important;
        box-shadow: 0 10px 26px rgba(15,23,42,.045) !important;
    }

    .timeline-event-card::before {
        width: 4px !important;
        border-radius: 999px !important;
        background: var(--priority-color, var(--priority-medium)) !important;
    }

    .timeline-event-card.status-concluido {
        opacity: .72 !important;
        filter: saturate(.72) !important;
    }

    .event-icon,
    .event-icon.category-trabalho,
    .event-icon.category-pessoal,
    .event-icon.category-estudos,
    .event-icon.category-outros {
        width: 38px !important;
        height: 38px !important;
        border-radius: 13px !important;
        color: var(--priority-color, var(--priority-medium)) !important;
        background: var(--priority-soft, var(--priority-medium-soft)) !important;
        font-size: .82rem !important;
    }

    .event-title-line {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        gap: 7px !important;
        align-items: start !important;
    }

    .event-title-line h3 {
        margin: 0 !important;
        color: #0b1733 !important;
        font-size: .86rem !important;
        line-height: 1.12 !important;
        letter-spacing: -.012em !important;
        font-weight: 900 !important;
    }

    .event-status {
        padding: 4px 7px !important;
        border-radius: 999px !important;
        font-size: .53rem !important;
        line-height: 1 !important;
        font-weight: 900 !important;
        white-space: nowrap !important;
    }

    .event-meta-line {
        gap: 5px 9px !important;
        margin-top: 8px !important;
        color: #6b7588 !important;
        font-size: .65rem !important;
        line-height: 1.15 !important;
        font-weight: 760 !important;
    }

    .event-meta-line i {
        margin-right: 4px !important;
        color: var(--priority-color, var(--priority-medium)) !important;
    }

    .event-content p {
        margin-top: 8px !important;
        color: #667085 !important;
        font-size: .70rem !important;
        line-height: 1.28 !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
    }

    .priority-alta {
        --priority-color: var(--priority-high) !important;
        --priority-soft: var(--priority-high-soft) !important;
    }

    .priority-media {
        --priority-color: var(--priority-medium) !important;
        --priority-soft: var(--priority-medium-soft) !important;
    }

    .priority-baixa {
        --priority-color: var(--priority-low) !important;
        --priority-soft: var(--priority-low-soft) !important;
    }

    .timeline-now-row {
        min-height: 24px !important;
        align-items: center !important;
    }

    .timeline-now-row .time-label.now {
        padding-top: 0 !important;
        color: var(--today-primary) !important;
        font-size: .80rem !important;
        line-height: 1 !important;
        font-weight: 900 !important;
    }

    .now-dot {
        left: 52px !important;
        width: 10px !important;
        height: 10px !important;
        border: 2px solid #ffffff !important;
        background: var(--today-primary) !important;
        box-shadow: none !important;
    }

    .now-line {
        height: 2px !important;
        border-radius: 999px !important;
        background: linear-gradient(90deg, var(--today-primary), #6d5df7) !important;
        box-shadow: none !important;
    }

    .available-slot {
        margin-left: 60px !important;
        min-height: 44px !important;
        border-radius: 15px !important;
        border: 1.5px dashed #d7dee9 !important;
        color: #8a94a8 !important;
        background: rgba(255,255,255,.74) !important;
        font-size: .72rem !important;
        font-weight: 800 !important;
    }

    .available-slot.big-slot {
        margin-left: 60px !important;
        min-height: 60px !important;
    }

    .mobile-bottom-nav.app-mobile-nav,
    .mobile-bottom-nav {
        left: 16px !important;
        right: 16px !important;
        bottom: calc(8px + env(safe-area-inset-bottom)) !important;
        min-height: 58px !important;
        height: 58px !important;
        border-radius: 22px !important;
        padding: 6px 8px !important;
        grid-template-columns: 1fr 1fr 54px 1fr 1fr !important;
        border-color: #edf0f6 !important;
        background: rgba(255,255,255,.98) !important;
        box-shadow: 0 16px 40px rgba(15,23,42,.15) !important;
    }

    .app-mobile-nav .bottom-nav-item,
    .mobile-bottom-nav a {
        min-height: 40px !important;
        border-radius: 14px !important;
        color: #667085 !important;
        font-size: .54rem !important;
        gap: 2px !important;
        font-weight: 800 !important;
    }

    .app-mobile-nav .bottom-nav-item i,
    .mobile-bottom-nav a i {
        font-size: .84rem !important;
    }

    .app-mobile-nav .bottom-nav-item.active:not(.bottom-nav-create) {
        color: var(--today-primary) !important;
        background: var(--today-primary-soft) !important;
    }

    .app-mobile-nav .bottom-nav-create,
    .mobile-bottom-nav .nav-plus {
        width: 50px !important;
        height: 50px !important;
        min-height: 50px !important;
        margin: -20px auto 0 !important;
        border-radius: 999px !important;
        background: linear-gradient(135deg, #5145ee, #4f46e5) !important;
        box-shadow: 0 14px 28px rgba(79,70,229,.32) !important;
    }

    .app-mobile-nav .bottom-nav-create i {
        font-size: 1.14rem !important;
    }

    .detail-priority-badge.priority-alta {
        color: #b91c1c !important;
        background: var(--priority-high-soft) !important;
    }

    .detail-priority-badge.priority-media {
        color: #9a3412 !important;
        background: var(--priority-medium-soft) !important;
    }

    .detail-priority-badge.priority-baixa {
        color: #047857 !important;
        background: var(--priority-low-soft) !important;
    }
}

@media (max-width: 380px) {
    .daily-date-block h1 { font-size: 1.10rem !important; }
    .day-strip { grid-auto-columns: 50px !important; gap: 10px !important; }
    .timeline-row,
    .timeline-now-row { grid-template-columns: 44px minmax(0,1fr) !important; gap: 10px !important; }
    .timeline-list::before { left: 53px !important; }
    .timeline-row::before { left: 48px !important; }
    .now-dot { left: 48px !important; }
    .available-slot,
    .available-slot.big-slot { margin-left: 54px !important; }
    .timeline-event-card { grid-template-columns: 34px minmax(0,1fr) !important; gap: 9px !important; }
    .event-icon,
    .event-icon.category-trabalho,
    .event-icon.category-pessoal,
    .event-icon.category-estudos,
    .event-icon.category-outros {
        width: 34px !important;
        height: 34px !important;
        border-radius: 12px !important;
    }
}
