/* ============================================
   NODE HUB - Mobile Responsive
   ============================================ */

/* Desktop: hide mobile-only elements */
.mobile-search-btn { display: none !important; }
.mobile-search-overlay { display: none; }
.login-title-mobile { display: none; }

@media (max-width: 768px) {
    html,
    body,
    body.login-page,
    .login-page {
        width: 100%;
        max-width: 100%;
        overflow-x: hidden !important;
        overscroll-behavior-x: none;
    }

    .container { padding: 16px; max-width: 100vw; width: 100%; box-sizing: border-box; }

    /* Topbar mobile */
    .topbar {
        --mobile-topbar-control: 34px;
        --mobile-topbar-gap: 5px;
        padding: 0 10px;
        gap: var(--mobile-topbar-gap);
    }
    .menu-toggle {
        margin-right: 0;
        width: var(--mobile-topbar-control);
        height: var(--mobile-topbar-control);
        flex: 0 0 var(--mobile-topbar-control);
        border-radius: 8px;
    }
    .topbar-brand { gap: var(--mobile-topbar-gap); min-width: 0; overflow: visible; flex: 0 0 auto; }
    .topbar-home-link { gap: var(--mobile-topbar-gap); min-width: 0; }
    .topbar-logo {
        width: var(--mobile-topbar-control);
        height: var(--mobile-topbar-control);
        flex: 0 0 var(--mobile-topbar-control);
        display: block;
        object-fit: cover;
        object-position: center;
        border-radius: 9px;
        background: transparent;
        color: transparent;
        font-size: 0;
        line-height: 0;
        text-indent: -9999px;
    }
    .topbar-title { font-size: 15px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .site-indicator {
        width: 100%;
        max-width: none;
        min-width: 0;
        height: var(--mobile-topbar-control);
        font-size: 10px;
        padding: 0 8px;
        gap: 4px;
        margin-left: 0;
        flex-shrink: 1;
        overflow: hidden;
        border-radius: 8px;
    }
    .site-indicator-code {
        display: block;
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    .site-switcher { margin-left: 0; min-width: 0; max-width: none; flex: 1 1 auto; }
    .site-switcher-dropdown {
        display: block;
        position: fixed;
        top: calc(var(--topbar-height) + 8px);
        right: 12px;
        width: min(320px, calc(100vw - 24px));
        max-height: 62vh;
        overflow-y: auto;
        z-index: 1200;
    }
    .topbar-search-area {
        margin: 0;
        flex: 1 1 auto;
        order: 3;
        margin-left: 0;
        min-width: 0;
        display: flex;
        align-items: center;
        gap: var(--mobile-topbar-gap);
    }
    .topbar-actions { flex-shrink: 0; gap: var(--mobile-topbar-gap); order: 4; }
    .topbar-btn {
        width: var(--mobile-topbar-control);
        height: var(--mobile-topbar-control);
        flex: 0 0 var(--mobile-topbar-control);
        border-radius: 8px;
    }
    .topbar-user {
        display: inline-flex;
        width: var(--mobile-topbar-control);
        height: var(--mobile-topbar-control);
        flex: 0 0 var(--mobile-topbar-control);
        padding: 0;
        justify-content: center;
        border-radius: 8px;
    }
    .topbar-user > span,
    .topbar-user .dropdown-chevron { display: none; }
    .topbar-user .topbar-avatar {
        width: 24px;
        height: 24px;
    }
    .topbar-notify { position: static; }
    .topbar-notify-btn {
        width: var(--mobile-topbar-control);
        height: var(--mobile-topbar-control);
        flex: 0 0 var(--mobile-topbar-control);
    }
    .topbar-notify-badge {
        top: -6px;
        right: -6px;
        min-width: 18px;
        height: 18px;
        font-size: 9px;
        padding: 0 4px;
    }
    .topbar-notify-panel {
        position: fixed;
        top: calc(var(--topbar-height) + 8px);
        left: 12px;
        right: 12px;
        width: auto;
        max-height: 62vh;
        border-radius: 12px;
        z-index: 1201;
    }
    .topbar-notify-item-link {
        grid-template-columns: 1fr;
        gap: 6px;
    }
    .topbar-notify-tag {
        justify-self: flex-start;
    }
    .topbar-notify-modal {
        padding: 12px;
        align-items: center !important;
        justify-content: center !important;
    }
    .topbar-notify-modal-dialog {
        width: min(560px, 94vw);
        height: min(74vh, 560px);
        max-height: min(74vh, 560px);
        border-radius: 14px;
    }
    .topbar-notify-modal-head {
        padding: 12px 14px;
    }
    .topbar-notify-modal-subtitle {
        font-size: 11px;
    }
    .topbar-notify-modal-meta {
        padding: 9px 14px;
    }
    .topbar-notify-modal-item a {
        grid-template-columns: 1fr;
        align-items: flex-start;
        gap: 8px;
    }
    .topbar-notify-modal-list {
        padding: 8px 10px 10px;
        gap: 6px;
    }
    .topbar-notify-modal-tag {
        justify-self: flex-start;
    }
    .topbar-notify-modal-foot {
        padding: 10px 14px;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }
    .topbar-notify-modal-foot .btn {
        width: 100%;
    }
    .sidebar { width: 260px; }

    /* Hide topbar search on mobile (show as overlay via JS) */
    .topbar-search { display: none; }
    .search-kbd { display: none; }

    /* Mobile search button */
    .mobile-search-btn { display: flex !important; }

    /* Mobile search overlay */
    .mobile-search-overlay {
        display: none;
        position: fixed;
        top: 0; left: 0; right: 0; bottom: 0;
        background: rgba(0,0,0,0.6);
        z-index: 9999;
        padding: 16px;
        padding-top: calc(var(--topbar-height, 56px) + 8px);
        backdrop-filter: blur(4px);
    }
    .mobile-search-overlay.active { display: block; }
    .mobile-search-overlay .mobile-search-box {
        background: var(--surface, #1e293b);
        border-radius: 12px;
        padding: 12px;
        box-shadow: 0 8px 32px rgba(0,0,0,0.3);
    }
    .mobile-search-overlay input {
        width: 100%; box-sizing: border-box;
        padding: 12px 16px;
        font-size: 16px;
        background: var(--bg, #0f172a);
        color: var(--text, #e2e8f0);
        border: 2px solid var(--border, #334155);
        border-radius: 10px;
        outline: none;
    }
    .mobile-search-overlay input:focus { border-color: var(--primary); }
    .mobile-search-overlay .mobile-search-results {
        max-height: 60vh;
        overflow-y: auto;
        margin-top: 8px;
    }
    .mobile-search-overlay .mobile-search-results a {
        display: flex; align-items: center; gap: 10px;
        padding: 12px; border-radius: 8px;
        color: var(--text); text-decoration: none;
        transition: background 0.15s;
    }
    .mobile-search-overlay .mobile-search-results a:hover,
    .mobile-search-overlay .mobile-search-results a:active {
        background: var(--primary-subtle, rgba(91, 55, 219, 0.1));
    }
    .mobile-search-overlay .mobile-search-results .search-result-name {
        font-weight: 600; font-size: 14px;
    }
    .mobile-search-overlay .mobile-search-results .search-result-meta {
        display: flex; gap: 6px; margin-top: 2px; font-size: 12px;
    }

    .main-content {
        padding: 0;
        margin-top: var(--topbar-height);
        min-height: auto;
        padding-bottom: calc(24px + env(safe-area-inset-bottom));
    }

    /* Breadcrumb */
    .breadcrumb {
        padding: 10px 16px;
        font-size: 12px;
        gap: 6px;
    }

    .page-header, .dashboard-header {
        flex-direction: column;
        gap: 12px;
        text-align: left;
        align-items: flex-start;
    }

    .login-top-strip { display: none; }
    .login-bg-grid { display: none; }
    .login-particles { display: none; }
    .login-page { background: #ffffff !important; }
    .login-page::after {
        display: none !important;
    }
    .login-page::before { display: none !important; }
    .login-nav { background: #ffffff; border-bottom: 1px solid #e4ebf7; }
    .login-nav-brand strong { color: #122642; }
    .login-nav-brand .brand-icon { box-shadow: none; }
    .login-nav { position: relative; top: 0; z-index: 8; }
    .login-nav,
    .login-nav-inner,
    .login-shell,
    .login-card,
    .login-showcase {
        width: 100%;
        max-width: 100%;
    }
    .login-nav-inner {
        min-height: 64px;
        padding: 9px 12px;
        flex-wrap: nowrap;
        gap: 8px;
        max-width: 440px;
        margin: 0 auto;
    }
    .login-nav-brand strong { font-size: 22px; letter-spacing: -0.02em; }
    .login-nav-brand .brand-icon { width: 38px; height: 38px; border-radius: 11px; }
    .login-nav-links { display: none; }
    .login-nav-actions {
        margin-left: auto;
        display: inline-flex;
        align-items: center;
        gap: 8px;
        flex-shrink: 0;
    }
    .login-nav-actions .login-nav-btn-ghost { display: inline-flex; }
    .login-nav-btn {
        min-height: 38px;
        padding: 8px 11px;
        font-size: 12px;
        border-radius: 11px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
        white-space: nowrap;
        flex-shrink: 0;
        line-height: 1;
        overflow: visible;
    }
    .login-nav-btn svg { width: 14px; height: 14px; flex-shrink: 0; }
    .login-nav-btn-primary { min-width: 82px; }
    .login-nav-btn-ghost { min-width: 72px; }
    .login-nav-btn-ghost {
        color: #214775 !important;
        border-color: #b7caea !important;
        background: linear-gradient(135deg, #f8fbff 0%, #eef4ff 100%) !important;
        box-shadow: 0 4px 12px rgba(30, 67, 119, 0.14);
    }
    .login-nav-btn-primary {
        color: #ffffff !important;
        border-color: #4252c4 !important;
        background: linear-gradient(135deg, #1f51c6 0%, #3650cf 52%, #5638d9 100%) !important;
        box-shadow: 0 8px 18px rgba(46, 61, 159, 0.36);
    }
    .login-nav-btn-ghost:hover,
    .login-nav-btn-ghost:focus-visible {
        color: #17365d !important;
        border-color: #9db7e3 !important;
        background: #ffffff !important;
    }
    .login-nav-btn-primary:hover,
    .login-nav-btn-primary:focus-visible {
        color: #ffffff !important;
        border-color: #3e47bf !important;
        background: linear-gradient(135deg, #1b45ad 0%, #2f48bb 52%, #4a2fcc 100%) !important;
    }
    .login-nav-btn-primary:active,
    .login-nav-btn-ghost:active {
        transform: translateY(0);
    }
    .login-page::before,
    .login-page::after,
    .login-shell::before,
    .login-shell::after {
        animation: none !important;
    }
    .login-shell::before,
    .login-shell::after {
        display: none !important;
    }
    .login-marquee-group[aria-hidden="true"] {
        display: none;
    }

    .login-shell {
        grid-template-columns: 1fr;
        padding: 12px 14px calc(82px + env(safe-area-inset-bottom));
        gap: 14px;
        min-height: calc(100dvh - var(--mobile-nav-height, 70px));
        min-height: calc(100svh - var(--mobile-nav-height, 70px));
        align-content: center;
        background: #ffffff;
        max-width: 440px;
        margin: 0 auto;
    }
    .login-showcase {
        display: none !important;
    }
    .login-showcase-tag {
        color: #f3f6ff;
        border-color: rgba(230, 238, 255, 0.42);
        background: linear-gradient(130deg, rgba(255, 255, 255, 0.22), rgba(210, 200, 255, 0.24));
    }
    .login-card { order: 1; }
    .login-showcase h1 { font-size: clamp(30px, 10vw, 44px); }
    .login-showcase > p {
        font-size: 16px;
        color: rgba(244, 248, 255, 0.96);
        text-shadow: 0 1px 0 rgba(8, 14, 38, 0.34);
    }
    .login-showcase h1 {
        color: #ffffff;
        text-shadow: 0 2px 12px rgba(4, 10, 30, 0.3);
    }
    .login-showcase-benefits {
        grid-template-columns: 1fr;
        gap: 8px;
        max-width: 100%;
    }
    .login-quick-links { gap: 8px; }
    .login-quick-link {
        grid-template-columns: 20px 1fr 20px;
        padding: 9px 10px;
        gap: 8px;
        border-color: rgba(243, 238, 255, 0.34);
        background: linear-gradient(150deg, rgba(56, 34, 130, 0.52), rgba(98, 77, 176, 0.44));
    }
    .login-quick-link .text { font-size: 13px; }
    .login-kpi-row { grid-template-columns: 1fr; gap: 8px; }
    .login-kpi-box strong { font-size: 22px; }
    .login-cta { font-size: 15px; padding: 10px 18px; }

    .login-card {
        max-width: 420px;
        width: 100%;
        margin: 0 auto;
        padding: 10px 0 0;
        gap: 13px;
        min-height: auto;
        border-radius: 0;
        background: transparent;
        border: 0;
        box-shadow: none;
    }
    .login-card .login-brand { display: none; }

    .login-brand { justify-content: flex-start; text-align: left; }
    .login-brand { gap: 10px; margin-bottom: 2px; }
    .login-brand .brand-icon,
    .login-brand > span:first-child { width: 40px; height: 40px; font-size: 13px; border-radius: 11px; }
    .login-brand h2 { font-size: 27px; }
    .login-card h3 { font-size: clamp(32px, 9vw, 38px); text-align: left; line-height: 1.04; letter-spacing: -0.03em; }
    .login-card-subtitle { display: none; }
    .login-title-desktop { display: none; }
    .login-title-mobile { display: inline; }
    .login-card .form-group { margin-bottom: 12px; }
    .login-card .form-group label { font-size: 12px; letter-spacing: 0.01em; color: #40516b; }
    .login-card .form-control {
        min-height: 52px;
        font-size: 17px;
        border-radius: 13px;
        border-color: #ced9ee;
        background: #ffffff;
        padding: 12px 14px;
    }
    .login-card .form-control::placeholder { color: #93a1b9; }
    .login-card .form-control:focus {
        background: #ffffff;
        border-color: #4d2cc3;
        box-shadow: 0 0 0 4px rgba(77, 44, 195, 0.14);
    }
    .login-actions { margin-top: 2px; }
    .login-actions .btn {
        min-height: 54px;
        border-radius: 13px;
        font-size: 18px;
        letter-spacing: 0;
        background: linear-gradient(135deg, #0f4b9a 0%, #3144bf 52%, #5633d8 100%);
        border-color: #3d3fbe;
        box-shadow: 0 12px 26px rgba(31, 41, 112, 0.35);
    }
    .login-actions .btn:hover { transform: translateY(-1px); }
    .login-actions .btn svg { width: 18px; height: 18px; }
    .erro { border-radius: 12px; }
    .info-login {
        font-size: 12px;
        border-radius: 12px;
        padding: 10px 11px;
        background: #f8faff;
        border: 1px solid #d9e3f5;
    }
    .login-mobile-marketing {
        display: block;
        margin-top: 2px;
        padding: 11px 12px;
        border-radius: 14px;
        border: 1px solid #d6e0f2;
        background: #fbfdff;
        box-shadow: 0 6px 14px rgba(18, 42, 88, 0.07);
    }
    .login-mobile-marketing-title {
        margin: 0 0 4px;
        font-size: 13px;
        font-weight: 800;
        letter-spacing: 0.02em;
        text-transform: uppercase;
        color: #28466f;
    }
    .login-mobile-marketing-subtitle {
        margin: 0 0 9px;
        font-size: 12px;
        line-height: 1.35;
        color: #5a7295;
    }
    .login-mobile-marketing-list {
        list-style: none;
        margin: 0;
        padding: 0;
        display: grid;
        gap: 7px;
    }
    .login-mobile-marketing-list li {
        display: grid;
        grid-template-columns: 20px 1fr;
        align-items: flex-start;
        gap: 8px;
        border: 1px solid #dce6f6;
        border-radius: 10px;
        background: #f7faff;
        padding: 8px 9px;
        font-size: 12px;
        color: #3f5a80;
        line-height: 1.3;
    }
    .login-mobile-marketing-bullet {
        width: 16px;
        height: 16px;
        border-radius: 999px;
        margin-top: 1px;
        background: linear-gradient(135deg, #2d58c9 0%, #4a41ca 100%);
        box-shadow: 0 4px 10px rgba(46, 57, 150, 0.34);
        position: relative;
    }
    .login-mobile-marketing-bullet::after {
        content: '';
        position: absolute;
        left: 5px;
        top: 4px;
        width: 6px;
        height: 4px;
        border-left: 2px solid #ffffff;
        border-bottom: 2px solid #ffffff;
        transform: rotate(-45deg);
    }
    .login-card-assurance {
        grid-template-columns: 1fr;
        gap: 7px;
        margin-top: 0;
    }
    .login-assurance-item {
        min-height: 50px;
        padding: 8px 10px;
        border-radius: 12px;
        display: grid;
        grid-template-columns: 30px 1fr;
        align-items: center;
        column-gap: 9px;
    }
    .login-assurance-icon {
        grid-row: span 2;
        width: 28px;
        height: 28px;
        border-radius: 10px;
    }
    .login-assurance-item strong { font-size: 12px; }
    .login-assurance-item span:last-child { font-size: 11px; }

    .login-steps-inner { padding: 34px 12px 48px; }
    .login-section-kicker {
        min-height: 28px;
        margin-bottom: 12px;
        padding: 6px 10px;
        font-size: 10px;
        letter-spacing: 0.06em;
    }
    .login-steps-inner h2 { font-size: clamp(28px, 8vw, 36px); margin-bottom: 16px; }
    .login-steps-grid { grid-template-columns: 1fr; gap: 10px; }
    .login-steps-grid article { border-radius: 16px; padding: 16px; }
    .login-step-card { gap: 8px; }
    .login-step-icon { width: 40px; height: 40px; }
    .login-step-icon svg { width: 20px; height: 20px; }
    .login-marquee { --marquee-edge: 40px; --marquee-speed: 26s; }
    .login-marquee-shell { padding: 10px 0; display: block; }
    .login-marquee-header { display: none; }
    .login-marquee-kicker { min-height: 30px; padding: 6px 11px 6px 9px; font-size: 10px; }
    .login-marquee-board { border-radius: 0; padding: 8px 0; gap: 8px; }
    .login-marquee-board::before,
    .login-marquee-board::after { width: 26px; }
    .login-marquee-lane {
        border-radius: 0;
        overflow-x: auto;
        scrollbar-width: none;
        -webkit-overflow-scrolling: touch;
    }
    .login-marquee-lane::-webkit-scrollbar { display: none; }
    .login-marquee-track { padding: 3px 0; animation: none; }
    .login-marquee-group { gap: 8px; padding: 0 6px; }
    .login-marquee-chip {
        min-height: 38px;
        font-size: 12px;
        padding: 6px 11px 6px 7px;
        border-radius: 13px;
    }
    .login-marquee-chip-icon { width: 24px; height: 24px; border-radius: 8px; }
    .login-marquee-chip-icon svg { width: 13px; height: 13px; }
    .login-stats-inner {
        grid-template-columns: 1fr 1fr;
        gap: 10px;
        padding: 10px 12px 12px;
    }
    .login-stat {
        min-height: 76px;
        padding: 10px;
        border-radius: 14px;
        gap: 4px;
    }
    .login-stat-value { font-size: clamp(24px, 7vw, 34px); }
    .login-stat-label { font-size: 11px; }
    .login-workflow-inner { padding: 34px 12px 42px; }
    .login-workflow-header h2 { font-size: clamp(28px, 8vw, 36px); }
    .login-workflow-header p { font-size: 15px; }
    .login-workflow-grid { grid-template-columns: 1fr; gap: 10px; }
    .login-workflow-card h3 { font-size: 18px; }

    .login-interactive-inner { padding: 34px 12px 44px; }
    .login-interactive-header h2 { font-size: clamp(28px, 8vw, 36px); }
    .login-interactive-header p { font-size: 15px; }
    .login-filters { gap: 8px; margin-bottom: 14px; padding: 0; border-radius: 0; width: 100%; top: calc(var(--mobile-nav-height, 70px) + 10px); }
    .login-filter-btn { min-height: 36px; padding: 7px 11px; font-size: 12px; border-radius: 10px; flex: 1 1 calc(50% - 6px); max-width: none; }
    .login-feature-grid {
        grid-template-columns: 1fr;
        gap: 10px;
    }
    .login-feature-card,
    .login-feature-card.is-expanded { grid-column: span 1; border-radius: 18px; }
    .login-feature-toggle { padding: 16px 14px 78px; gap: 12px; }
    .login-feature-toggle::after {
        left: 14px;
        right: 14px;
        bottom: 14px;
        height: 48px;
        border-radius: 12px;
    }
    .login-feature-card.is-expanded .login-feature-toggle {
        padding-bottom: 104px;
    }
    .login-feature-card.is-expanded .login-feature-toggle::after {
        bottom: 14px;
        height: 72px;
        border-radius: 14px;
    }
    .login-feature-icon { width: 44px; height: 44px; border-radius: 12px; }
    .login-feature-icon svg { width: 20px; height: 20px; }
    .login-feature-title { font-size: 18px; }
    .login-feature-summary { margin-top: 8px; font-size: 14px; }
    .login-feature-toggle-indicator { width: 30px; height: 30px; border-radius: 10px; }
    .login-feature-details { padding: 0 14px 14px; gap: 12px; }
    .login-feature-detail-label { font-size: 10px; }
    .login-feature-details p,
    .login-feature-detail-list { font-size: 13px; }
    .login-feature-action { width: 100%; justify-content: center; display: inline-flex; min-height: 38px; }
    .login-help-inner,
    .login-contact-inner,
    .login-faq-inner { padding: 34px 12px; }
    .login-help-header h2,
    .login-contact-header h2,
    .login-faq-header h2 { font-size: clamp(28px, 8vw, 36px); }
    .login-help-grid,
    .login-contact-grid,
    .login-faq-grid { grid-template-columns: 1fr; gap: 10px; }
    .login-help-item,
    .login-faq-item,
    .login-contact-card { border-radius: 16px; }
    .login-help-action { width: 100%; justify-content: center; display: inline-flex; }
    .login-footer-inner {
        padding: 16px 12px 20px;
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    .login-footer-brand .brand-icon { width: 34px; height: 34px; border-radius: 10px; }
    .login-footer-brand strong { font-size: 14px; }
    .login-footer-brand span:last-child,
    .login-footer-meta { font-size: 12px; }
    .login-footer-social { margin-left: 0; }
    .login-social-link { width: 34px; height: 34px; border-radius: 10px; }
    .login-footer-meta { justify-content: flex-start; gap: 6px 14px; }

    .btn { min-height: 44px; font-size: 14px; }
    .btn-sm { min-height: 36px; font-size: 12px; }

    .login-marquee,
    .login-stats {
        display: none !important;
    }

    .login-mobile-cue {
        position: fixed;
        left: 50%;
        right: auto;
        bottom: calc(10px + env(safe-area-inset-bottom));
        z-index: 15;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 7px;
        width: auto;
        min-width: 162px;
        margin: 0;
        min-height: 40px;
        padding: 8px 13px;
        border-radius: 999px;
        border: 1px solid rgba(68, 90, 181, 0.58);
        background: linear-gradient(135deg, rgba(36, 78, 196, 0.9) 0%, rgba(74, 61, 200, 0.9) 100%);
        color: #ffffff;
        font-size: 12px;
        font-weight: 700;
        letter-spacing: 0.005em;
        text-decoration: none;
        box-shadow: 0 7px 14px rgba(35, 52, 125, 0.28);
        animation: loginMobileCuePulseSoft 2s ease-in-out infinite;
        transform: translateX(-50%);
        transition: opacity 180ms ease, transform 180ms ease, box-shadow 180ms ease;
    }
    .login-mobile-cue:hover { box-shadow: 0 10px 18px rgba(35, 52, 125, 0.34); }

    .login-mobile-cue svg {
        width: 14px;
        height: 14px;
        fill: none;
        stroke: currentColor;
        stroke-width: 2.1;
        stroke-linecap: round;
        stroke-linejoin: round;
    }

    .login-mobile-cue.is-hidden {
        opacity: 0.9;
        pointer-events: auto;
        transform: translateX(-50%);
        animation: loginMobileCuePulseSoft 2s ease-in-out infinite;
    }
    @keyframes loginMobileCuePulseSoft {
        0%, 100% { opacity: 0.88; box-shadow: 0 7px 14px rgba(35, 52, 125, 0.26); }
        50% { opacity: 1; box-shadow: 0 10px 18px rgba(35, 52, 125, 0.33); }
    }

    .dashboard-actions {
        flex-direction: column;
        width: 100%;
    }
    .dashboard-actions .btn { width: 100%; justify-content: center; }
    .dashboard-actions .btn-mobile-hide-analytics { display: none !important; }
    .dashboard-mobile-hide-header { display: none !important; }

    .home-site-strip {
        grid-template-columns: 1fr;
        margin: -4px 0 14px;
    }

    .home-site-strip-cover {
        order: 1;
        min-height: 120px;
        border-left: 0;
        border-bottom: 1px solid rgba(209, 224, 245, 0.75);
    }

    .home-site-strip-content {
        order: 2;
        padding: 12px;
        overflow: visible;
    }

    .home-site-strip-head h3 {
        font-size: 20px;
    }

    .home-site-strip-head {
        align-items: center;
        flex-wrap: nowrap;
        gap: 8px;
    }

    .home-site-strip-title-main {
        flex: 1 1 auto;
        min-width: 0;
    }

    .home-site-strip-iot {
        flex: 0 0 auto;
        justify-content: flex-end;
        flex-wrap: nowrap;
        gap: 6px;
        width: auto;
        max-width: 64%;
        margin-left: auto;
    }

    .home-iot-offline {
        min-height: 28px;
        padding: 5px 8px;
        font-size: 11px;
    }

    .home-iot-door-summary {
        min-height: 38px;
    }

    .home-iot-temp-carousel {
        max-width: 132px;
    }

    .home-iot-temp-carousel--flat {
        max-width: 106px;
    }

    .home-iot-door-group {
        flex-wrap: nowrap;
        gap: 0;
    }

    .home-site-strip-monitoring {
        display: none !important;
    }

    .home-site-strip-address {
        display: block !important;
        overflow: visible !important;
        -webkit-line-clamp: unset !important;
        line-clamp: unset !important;
        -webkit-box-orient: initial !important;
        white-space: normal !important;
        overflow-wrap: anywhere !important;
    }

    .home-site-strip-tags {
        margin-top: 4px;
        align-items: flex-start;
    }

    .home-site-strip-tag {
        height: auto;
        max-width: 100%;
        white-space: normal;
        overflow-wrap: anywhere;
        text-align: left;
    }

    /* Stats Grid */
    .stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 12px;
    }

    .stat-card {
        padding: 16px;
        gap: 12px;
        border-radius: var(--radius);
    }

    .stat-icon {
        width: 42px;
        height: 42px;
        font-size: 20px;
        border-radius: var(--radius-sm);
    }

    .stat-info h3 { font-size: 22px; }
    .stat-info p { font-size: 12px; }

    /* Forms */
    .form-row { grid-template-columns: 1fr; }
    .form-actions { flex-direction: column; }
    .form-actions .btn { width: 100%; }

    /* Filters */
    .filters-bar form,
    .filters-form {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .filter-group { width: 100%; }

    .filters-equipamentos .filter-group { grid-column: span 1; }

    .filters-equipamentos .filter-actions {
        flex-direction: column;
    }

    .tool-empty-state {
        padding: 24px 16px !important;
    }

    .tool-empty-actions {
        width: 100%;
        flex-direction: column;
        align-items: stretch;
    }

    .tool-empty-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .filters-mobile-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        font-size: 12px;
        color: var(--muted);
        margin-bottom: 8px;
    }

    .filters-toggle {
        border: 1px solid var(--border);
        background: var(--surface);
        color: var(--text);
        padding: 8px 14px;
        border-radius: var(--radius-full);
        font-size: 12px;
        font-weight: 600;
        cursor: pointer;
        transition: var(--transition);
    }

    .filters-toggle:hover { background: var(--bg-alt); }

    #dashboard-filters.filters-collapsed,
    .filters-collapsed {
        display: none;
    }

    /* Tables */
    .table-responsive {
        font-size: 13px;
        border-radius: var(--radius);
    }

    .table th, .table td { padding: 10px 10px; }

    /* Stacked table on mobile */
    .table-stacked thead { display: none; }

    .table-stacked tbody tr {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px 12px;
        padding: 14px;
        margin-bottom: 10px;
        background: var(--surface);
        border: 1px solid var(--border-light);
        border-radius: var(--radius);
        box-shadow: var(--shadow-xs);
    }

    .table-stacked tbody td {
        border: none;
        padding: 0;
        display: flex;
        flex-direction: column;
        gap: 3px;
        min-width: 0;
    }

    .table-stacked tbody td::before {
        content: attr(data-label);
        font-size: 10px;
        font-weight: 700;
        letter-spacing: 0.06em;
        text-transform: uppercase;
        color: var(--muted-light);
    }

    .table-stacked tbody td.actions,
    .table-stacked tbody td.col-localizacao,
    .table-stacked tbody td.col-pendencia {
        grid-column: 1 / -1;
    }

    .table-stacked tbody td.actions {
        display: flex;
        flex-direction: row;
        justify-content: flex-end;
        gap: 8px;
        padding-top: 8px;
        border-top: 1px solid var(--border-light);
        margin-top: 4px;
    }

    .table-stacked tbody td.actions::before { display: none; }

    .table-stacked tbody tr.row-status-ok { border-left: 4px solid var(--success); }
    .table-stacked tbody tr.row-status-nok { border-left: 4px solid var(--danger); }
    .table-stacked tbody tr.row-status-vago { border-left: 4px solid var(--info); }
    .table-stacked tbody tr.row-status-manutencao { border-left: 4px solid var(--warning); }

    /* Dashboard (mobile): modo lista ultra compacto (2 linhas) */
    #dashboardEquipViewTable .table-stacked tbody tr {
        grid-template-columns: minmax(0, 1fr) auto auto;
        grid-template-areas:
            "name status status"
            "codigo fotos actions";
        align-items: center;
        gap: 7px 10px;
        padding: 10px 12px;
        margin-bottom: 6px;
        border-radius: 12px;
        background: linear-gradient(160deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
        box-shadow: inset 0 1px 0 rgba(255,255,255,0.03), 0 4px 12px rgba(2,8,24,0.16);
    }

    /* Exibe somente campos essenciais */
    #dashboardEquipViewTable .table-stacked tbody td:nth-child(1),
    #dashboardEquipViewTable .table-stacked tbody td:nth-child(5),
    #dashboardEquipViewTable .table-stacked tbody td:nth-child(7) { display: none; }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(2) {
        grid-area: name;
        display: block;
        font-size: 0.98rem;
        font-weight: 800;
        line-height: 1.15;
        color: var(--text);
        padding: 0;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(3) {
        grid-area: codigo;
        display: flex;
        align-items: center;
        gap: 4px;
        padding: 0;
        min-width: 0;
        color: var(--muted);
        font-size: 12px;
        font-weight: 700;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(4) {
        grid-area: status;
        display: flex;
        justify-content: flex-end;
        align-items: center;
        padding: 0;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(6) {
        grid-area: fotos;
        display: flex;
        justify-content: flex-end;
        align-items: center;
        gap: 4px;
        padding: 0;
        min-width: 44px;
        color: var(--muted);
        font-size: 12px;
        font-weight: 700;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions {
        grid-area: actions;
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: flex-end;
        flex-wrap: nowrap;
        gap: 5px;
        padding: 0;
        margin: 0;
        border-top: 0;
        min-width: 64px;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions::before {
        display: none;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions .btn {
        width: 30px;
        min-width: 30px;
        height: 28px;
        min-height: 28px;
        padding: 0;
        justify-content: center;
        align-items: center;
        gap: 0;
        border-radius: 8px;
        box-shadow: none;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions .btn-info {
        background: rgba(59,130,246,0.14);
        border-color: rgba(59,130,246,0.4);
        color: #93c5fd;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions .btn-warning {
        background: rgba(245,158,11,0.14);
        border-color: rgba(245,158,11,0.42);
        color: #fcd34d;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions .btn .btn-text {
        display: none;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions .btn svg {
        width: 14px;
        height: 14px;
    }

    /* rótulos limpos e pequenos */
    #dashboardEquipViewTable .table-stacked tbody td:nth-child(2)::before { display: none; }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(3)::before {
        content: 'COD';
        font-size: 9px;
        letter-spacing: 0.08em;
        opacity: 0.72;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(4)::before {
        content: 'STATUS';
        font-size: 9px;
        letter-spacing: 0.08em;
        margin-right: 6px;
        opacity: 0.72;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(6)::before {
        content: 'FOTOS';
        font-size: 9px;
        letter-spacing: 0.08em;
        opacity: 0.72;
    }

    /* Dashboard (mobile) override final: lista compacta limpa */
    #dashboardEquipViewTable .table-stacked tbody tr {
        grid-template-columns: minmax(0, 1fr) auto auto auto !important;
        grid-template-areas:
            "name status status status"
            "codigo fotos actions actions" !important;
        align-items: center !important;
        gap: 6px 10px !important;
        padding: 10px 12px !important;
        margin-bottom: 6px !important;
        border-radius: 12px !important;
        background: rgba(255,255,255,0.02) !important;
        box-shadow: inset 0 1px 0 rgba(255,255,255,0.03) !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(1),
    #dashboardEquipViewTable .table-stacked tbody td:nth-child(5),
    #dashboardEquipViewTable .table-stacked tbody td:nth-child(7) { display: none !important; }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(2) {
        grid-area: name !important;
        display: block !important;
        padding: 0 !important;
        min-width: 0 !important;
        font-size: 0.97rem !important;
        font-weight: 800 !important;
        line-height: 1.12 !important;
        color: var(--text) !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.equip-name-cell { text-align: left !important; }

    #dashboardEquipViewTable .table-stacked tbody td.equip-name-cell .equip-name-line {
        display: block !important;
        width: 100% !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(4) {
        grid-area: status !important;
        display: flex !important;
        justify-content: flex-end !important;
        align-items: center !important;
        justify-self: end !important;
        margin-left: auto !important;
        padding: 0 !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(3) {
        grid-area: codigo !important;
        display: block !important;
        padding: 0 !important;
        min-width: 0 !important;
        color: var(--muted) !important;
        font-size: 12px !important;
        font-weight: 700 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(6) {
        grid-area: fotos !important;
        display: flex !important;
        justify-content: flex-end !important;
        align-items: center !important;
        gap: 4px !important;
        min-width: 42px !important;
        padding: 0 !important;
        color: var(--muted) !important;
        font-size: 12px !important;
        font-weight: 700 !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions {
        grid-area: actions !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        gap: 5px !important;
        flex-wrap: nowrap !important;
        min-width: 76px !important;
        padding: 0 !important;
        margin: 0 !important;
        border-top: 0 !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions::before { display: none !important; }

    #dashboardEquipViewTable .table-stacked tbody td.actions .btn {
        width: 38px !important;
        min-width: 38px !important;
        height: 30px !important;
        min-height: 30px !important;
        padding: 0 !important;
        border-radius: 8px !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 0 !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions .btn-info {
        background: rgba(59,130,246,0.14) !important;
        border-color: rgba(59,130,246,0.4) !important;
        color: #93c5fd !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions .btn-warning {
        background: rgba(245,158,11,0.14) !important;
        border-color: rgba(245,158,11,0.42) !important;
        color: #fcd34d !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions .btn .btn-text { display: none !important; }
    #dashboardEquipViewTable .table-stacked tbody td.actions .btn svg { width: 15px !important; height: 15px !important; }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(2)::before,
    #dashboardEquipViewTable .table-stacked tbody td:nth-child(3)::before,
    #dashboardEquipViewTable .table-stacked tbody td:nth-child(4)::before { display: none !important; }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(6)::before {
        content: 'FOTOS' !important;
        display: inline-block !important;
        font-size: 9px !important;
        letter-spacing: 0.08em !important;
        opacity: 0.72 !important;
        margin-right: 4px !important;
    }

    /* Nome + derivação: mesma linha, alinhados à esquerda */
    #dashboardEquipViewTable .table-stacked tbody td.equip-name-cell {
        grid-area: name !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
        text-align: left !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        gap: 6px !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.equip-name-cell .equip-name-text {
        display: inline-block !important;
        flex: 0 1 auto !important;
        max-width: 60% !important;
        min-width: 0 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.equip-name-cell .equip-parent-inline {
        display: inline-block !important;
        flex: 0 1 auto !important;
        max-width: 38% !important;
        margin-left: 0 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    /* Recent Updates mobile cards */
    .recent-updates .table-responsive {
        overflow: visible;
        background: transparent;
        box-shadow: none;
        border: none;
    }

    .recent-updates .recent-table thead { display: none; }

    .recent-updates .recent-table tbody tr {
        display: flex;
        flex-wrap: wrap;
        gap: 8px 10px;
        padding: 12px;
        margin-bottom: 8px;
        background: var(--surface);
        border: 1px solid var(--border-light);
        border-radius: var(--radius);
        box-shadow: var(--shadow-xs);
    }

    .recent-updates .recent-table tbody td { border: none; padding: 0; }

    .recent-updates .recent-table .cell-type { order: 1; }
    .recent-updates .recent-table .cell-name {
        order: 2;
        font-weight: 600;
        flex: 1 1 auto;
        font-size: 13px;
    }
    .recent-updates .recent-table .cell-master { display: none; }
    .recent-updates .recent-table .cell-status { order: 3; }
    .recent-updates .recent-table .cell-updated {
        order: 4;
        width: 100%;
        color: var(--muted);
        font-size: 10px;
    }
    .recent-updates .recent-table .cell-actions {
        order: 5;
        width: 100%;
        display: flex;
        gap: 8px;
        justify-content: flex-end;
    }

    .recent-updates .recent-table .btn-icon,
    .equipamentos-cards .btn-icon {
        width: auto;
        height: auto;
        padding: 6px 10px;
        font-size: 12px;
        line-height: 1;
    }

    .recent-updates .recent-table .btn-icon::before,
    .equipamentos-cards .btn-icon::before { display: none; }

    .recent-updates .recent-table .btn-text,
    .equipamentos-cards .btn-text { display: inline; }

    /* Detail */
    .detail-grid { grid-template-columns: 1fr; }
    .equipamento-detail { padding: 20px; border-radius: var(--radius-lg); }
    .detail-header { flex-direction: column; align-items: flex-start; gap: 12px; }

    /* Photos */
    .fotos-grid, .fotos-gallery { grid-template-columns: repeat(2, 1fr); }
    .foto-item__overlay,
    .foto-card__overlay { opacity: 1; }
    .foto-item--interactive img,
    .foto-card--interactive img { filter: brightness(0.75); }

    /* Backup */
    .backup-actions { grid-template-columns: 1fr; }
    .backup-grid { grid-template-columns: 1fr; gap: 14px; }
    .backup-layout .stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        align-items: stretch;
    }

    .backup-layout .backup-stat-card--saved {
        order: 1;
    }

    .backup-layout .backup-stat-card--author {
        order: 2;
    }

    .backup-layout .backup-stat-card--last {
        order: 3;
        grid-column: 1 / -1;
    }

    .backup-layout .backup-stat-card {
        align-items: flex-start;
        gap: 10px;
        min-width: 0;
        padding: 14px;
    }

    .backup-layout .backup-stat-card .stat-icon {
        width: 38px;
        height: 38px;
        min-width: 38px;
    }

    .backup-layout .backup-stat-card .stat-info {
        min-width: 0;
    }

    .backup-layout .backup-stat-date {
        font-size: clamp(17px, 4.8vw, 20px);
        line-height: 1.05;
        max-width: 100%;
    }

    .backup-layout .backup-stat-date span + span {
        font-size: 0.94em;
    }

    .backup-panel {
        padding: 20px;
        border-radius: var(--radius-lg);
    }

    .backup-panel p {
        font-size: 13px;
        margin-bottom: 14px;
    }

    .backup-schedule-form {
        gap: 10px;
    }

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

    .backup-schedule-grid .form-group label {
        margin-bottom: 6px;
        font-size: 12px;
        line-height: 1.1;
    }

    .backup-schedule-grid .form-control {
        min-height: 46px;
        padding: 9px 12px;
        font-size: 14px;
    }

    .backup-schedule-form .state-note {
        margin-top: 0;
        font-size: 11px;
        line-height: 1.35;
    }

    .backup-panel .backup-schedule-form > .btn.btn-primary {
        width: 100% !important;
        min-width: 0;
        min-height: 46px;
        align-self: stretch;
    }

    .panel-btns {
        gap: 8px;
    }

    .panel-btns .btn {
        padding: 11px 14px;
        font-size: 13px;
        border-radius: var(--radius);
    }

    .backup-site-transfer-grid {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }

    .backup-site-transfer .backup-panel {
        padding: 16px;
    }

    .backup-site-transfer .backup-panel-header {
        align-items: flex-start;
        gap: 12px;
    }

    .backup-site-transfer .backup-panel-icon {
        width: 42px;
        height: 42px;
        min-width: 42px;
        border-radius: 12px;
    }

    .backup-site-transfer .backup-panel-header h3 {
        font-size: 17px;
        line-height: 1.25;
    }

    .backup-site-transfer .backup-panel-header p {
        font-size: 13px;
        line-height: 1.45;
        margin-bottom: 0;
    }

    .backup-site-transfer .backup-import-actions {
        grid-template-columns: 1fr;
    }

    .panel-note {
        font-size: 11px;
        margin-top: 10px;
    }

    /* Backup list: hide table, show cards */
    .backup-table-desktop { display: none !important; }
    .backup-cards-mobile {
        display: block;
        padding-bottom: calc(92px + env(safe-area-inset-bottom));
    }

    .backup-card-item {
        border-radius: var(--radius);
        padding: 14px 14px 14px 18px;
    }

    .backup-card-date {
        padding-left: 0;
        margin-bottom: 12px;
        padding-top: 8px;
        border-top: 1px solid var(--border-light);
    }

    .backup-card-actions .btn {
        min-height: 42px;
        font-size: 13px;
        border-radius: var(--radius-sm);
    }

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

    .backup-card-actions .btn,
    .backup-card-actions .backup-card-form {
        width: 100%;
        min-width: 0;
    }

    .backup-card-actions .backup-card-form .btn {
        height: 100%;
    }

    .backups-list .section-header {
        margin-bottom: 12px;
    }

    .backups-list .section-header h3 {
        font-size: 16px;
    }

    /* Config */
    .config-sections { grid-template-columns: 1fr; }

    /* Upload */
    .upload-item { flex-direction: column; align-items: stretch; }
    .upload-actions { flex-direction: column; }
    .upload-item-inline .form-control { width: 100%; min-width: 0; }

    .upload-actions-inline {
        width: 100%;
        flex-direction: row;
        flex-wrap: wrap;
    }

    .upload-chip {
        flex: 1 1 48%;
        justify-content: center;
        font-size: 14px;
    }

    .upload-previews { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .upload-preview-item img { height: 110px; }
    .upload-shell { padding: 14px; }
    .upload-toolbar { justify-content: center; }

    /* Equipment cards */
    .equipamentos-cards { grid-template-columns: 1fr; }
    .equip-grid-view .equipamento-card .equipamento-card-link { padding-right: 44px; }
    .equipamento-card-actions {
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        gap: 8px;
    }

    /* Mobile nav */
    .mobile-nav { display: flex; }

    /* Footer above mobile nav */
    .footer {
        padding: 18px 16px calc(28px + env(safe-area-inset-bottom));
        margin-bottom: 0;
    }

    /* Modal */
    .modal-content { max-width: 95%; margin-top: 20px; }
    .close { top: 10px; right: 15px; font-size: 30px; width: 36px; height: 36px; }

    /* Toast */
    .toast-container {
        left: 12px;
        right: 12px;
    }

    .toast {
        min-width: auto;
        max-width: 100%;
    }

    /* Confirm modal */
    .confirm-modal { padding: 24px; max-width: 92%; }
    .confirm-actions { flex-direction: column; }
    .confirm-actions .btn { width: 100%; min-width: auto; }

    /* Pagination numeric */
    .pagination { gap: 4px; }
    .page-num { width: 32px; height: 32px; font-size: 12px; }
    .page-nav { padding: 0 8px; height: 32px; font-size: 12px; }
    .page-ellipsis { width: 24px; }

    /* Timeline */
    .timeline { padding-left: 28px; }
    .timeline-dot { left: -28px; width: 18px; height: 18px; }
    .timeline-content { padding: 14px; }
    .timeline-header { flex-direction: column; gap: 4px; }

    /* Lightbox */
    .lightbox-img { max-width: 95vw; max-height: 75vh; border-radius: var(--radius); }
    .lightbox-nav { width: 36px; height: 36px; }
    .lightbox-prev { left: 8px; }
    .lightbox-next { right: 8px; }

}

/* ============================================
   NODEHUB V6 FINAL MOBILE SAFETY OVERRIDES
   ============================================ */
@media (max-width: 768px) {
    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        grid-template-columns: none !important;
        gap: 14px !important;
        overflow: hidden !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero h1,
    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero h2 {
        display: block !important;
        min-width: 0 !important;
        max-width: 100% !important;
        overflow-wrap: anywhere !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero > .page-header-actions,
    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero > .dashboard-actions,
    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero > .actions,
    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero > .cadastro-header-actions {
        position: static !important;
        display: grid !important;
        grid-template-columns: 1fr !important;
        align-items: stretch !important;
        justify-content: stretch !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        margin: 0 !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero > .page-header-actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero > .dashboard-actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero > .actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero > .cadastro-header-actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero > a.btn,
    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero > .btn {
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        white-space: normal !important;
    }

    body:not(.login-page) .dash-tabs {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow: hidden !important;
    }

    body:not(.login-page) .dash-tab {
        min-width: 0 !important;
        width: 100% !important;
        padding: 8px 7px !important;
        gap: 5px !important;
        white-space: normal !important;
    }

    body:not(.login-page) .dash-tab span:not(.dash-tab-count) {
        min-width: 0 !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }
}

/* Shared mobile page header pattern. Keep it opt-in so HUD/dashboard layouts stay untouched. */
.nh-mobile-header-help {
    display: none !important;
}

.nh-mobile-header-back {
    display: none !important;
}

@media (max-width: 768px) {
    .nh-desktop-help {
        display: none !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard {
        display: grid !important;
        grid-template-columns: 32px minmax(0, 1fr) !important;
        align-items: center !important;
        gap: 14px 12px !important;
        text-align: left !important;
        position: relative !important;
        overflow: visible !important;
        z-index: 30 !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard.has-open-help {
        z-index: 1500 !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard > .page-header-main {
        display: contents !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard h2 {
        grid-column: 1 / -1 !important;
        grid-row: 1 !important;
        width: 100% !important;
        min-width: 0 !important;
        margin: 0 !important;
        line-height: 1.12 !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard .page-subtitle.mobile-help-source,
    body:not(.login-page) .page-header.nh-mobile-standard > .nh-mobile-header-help {
        grid-column: 1 !important;
        grid-row: 2 !important;
        justify-self: start !important;
        align-self: center !important;
        margin: 0 !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard > .nh-mobile-header-help {
        display: inline-flex !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard > .page-header-actions,
    body:not(.login-page) .page-header.nh-mobile-standard > .devtools-header-actions,
    body:not(.login-page) .page-header.nh-mobile-standard > .dashboard-actions,
    body:not(.login-page) .page-header.nh-mobile-standard > .actions,
    body:not(.login-page) .page-header.nh-mobile-standard > .cadastro-header-actions,
    body:not(.login-page) .page-header.nh-mobile-standard > .nh-mobile-header-back,
    body:not(.login-page) .page-header.nh-mobile-standard > a.btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .btn {
        grid-column: 2 !important;
        grid-row: 2 !important;
        justify-self: end !important;
        align-self: center !important;
        width: auto !important;
        max-width: 100% !important;
        min-width: 0 !important;
        margin: 0 !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard > .page-header-actions,
    body:not(.login-page) .page-header.nh-mobile-standard > .devtools-header-actions,
    body:not(.login-page) .page-header.nh-mobile-standard > .dashboard-actions,
    body:not(.login-page) .page-header.nh-mobile-standard > .actions,
    body:not(.login-page) .page-header.nh-mobile-standard > .cadastro-header-actions,
    body:not(.login-page) .page-header.nh-mobile-standard > .nh-mobile-header-back {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        flex-wrap: nowrap !important;
        gap: 8px !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard > .page-header-actions:empty,
    body:not(.login-page) .page-header.nh-mobile-standard > .devtools-header-actions:empty,
    body:not(.login-page) .page-header.nh-mobile-standard > .dashboard-actions:empty,
    body:not(.login-page) .page-header.nh-mobile-standard > .actions:empty,
    body:not(.login-page) .page-header.nh-mobile-standard > .cadastro-header-actions:empty {
        display: none !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard > a.btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .page-header-actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .devtools-header-actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .dashboard-actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .cadastro-header-actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .nh-mobile-header-back {
        min-height: 52px !important;
        padding-inline: 18px !important;
        justify-content: center !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard > a.btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .page-header-actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .devtools-header-actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .dashboard-actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .cadastro-header-actions .btn,
    body:not(.login-page) .page-header.nh-mobile-standard > .nh-mobile-header-back {
        border-color: rgba(164, 188, 232, 0.48) !important;
        background: linear-gradient(135deg, #1c4f97 0%, #2a5ea6 58%, #6850e5 100%) !important;
        color: #f7fbff !important;
        box-shadow: 0 8px 18px rgba(9, 35, 78, 0.22) !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard > a.btn:hover,
    body:not(.login-page) .page-header.nh-mobile-standard > .btn:hover,
    body:not(.login-page) .page-header.nh-mobile-standard > .page-header-actions .btn:hover,
    body:not(.login-page) .page-header.nh-mobile-standard > .devtools-header-actions .btn:hover,
    body:not(.login-page) .page-header.nh-mobile-standard > .dashboard-actions .btn:hover,
    body:not(.login-page) .page-header.nh-mobile-standard > .actions .btn:hover,
    body:not(.login-page) .page-header.nh-mobile-standard > .cadastro-header-actions .btn:hover,
    body:not(.login-page) .page-header.nh-mobile-standard > .nh-mobile-header-back:hover {
        background: linear-gradient(135deg, #1a498b 0%, #275497 58%, #5b42d3 100%) !important;
        color: #f7fbff !important;
        box-shadow: 0 10px 22px rgba(8, 32, 69, 0.28) !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard .equipamentos-header-actions {
        width: auto !important;
    }

    body:not(.login-page) .nh-page {
        width: min(calc(100% - 20px), 100%);
        max-width: none;
    }

    body:not(.login-page) .nh-hero {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 14px !important;
        padding: 14px !important;
        border-radius: 14px !important;
        text-align: left !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero {
        grid-template-columns: none !important;
    }

    body:not(.login-page) .nh-hero-main,
    body:not(.login-page) .nh-hero .page-header-main,
    body:not(.login-page) .nh-hero .dash-hero-text {
        align-items: flex-start !important;
        width: 100% !important;
    }

    body:not(.login-page) .nh-hero-main {
        display: flex !important;
        gap: 12px !important;
    }

    body:not(.login-page) .nh-hero .page-header-main,
    body:not(.login-page) .nh-hero .dash-hero-text {
        display: grid !important;
        gap: 4px !important;
    }

    body:not(.login-page) .nh-hero-icon {
        width: 36px !important;
        height: 36px !important;
        flex: 0 0 36px !important;
        border-radius: 10px !important;
    }

    body:not(.login-page) .nh-hero h1,
    body:not(.login-page) .nh-hero h2 {
        font-size: 25px !important;
        line-height: 1.08 !important;
    }

    body:not(.login-page) .nh-hero .page-subtitle,
    body:not(.login-page) .nh-hero .dash-subtitle,
    body:not(.login-page) .nh-hero-copy p {
        max-width: none !important;
        font-size: 13px !important;
    }

    body:not(.login-page) .nh-hero-actions,
    body:not(.login-page) .nh-hero .page-header-actions,
    body:not(.login-page) .nh-hero .dashboard-actions,
    body:not(.login-page) .nh-hero .actions,
    body:not(.login-page) .nh-hero .dash-hero-actions {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        flex-wrap: wrap !important;
        gap: 10px !important;
        width: 100% !important;
        margin-left: 0 !important;
    }

    body:not(.login-page) .nh-context-chips {
        width: 100%;
        justify-content: flex-start;
    }

    body:not(.login-page) .nh-panel,
    body:not(.login-page) .nh-page .info-section,
    body:not(.login-page) .nh-page .filters-bar,
    body:not(.login-page) .nh-page .backup-panel,
    body:not(.login-page) .nh-page .rel-cards-section,
    body:not(.login-page) .nh-page .rel-info-section,
    body:not(.login-page) .nh-page .tech-section,
    body:not(.login-page) .nh-page .review-site-section {
        border-radius: 14px !important;
    }

    body:not(.login-page) .nh-panel {
        padding: 14px !important;
        gap: 14px !important;
    }

    body:not(.login-page) .nh-panel-head,
    body:not(.login-page) .nh-page .info-section__header,
    body:not(.login-page) .nh-page .backup-panel-header,
    body:not(.login-page) .nh-page .rel-section-head,
    body:not(.login-page) .nh-page .spare-form-section-head {
        display: grid !important;
        gap: 6px !important;
    }

    body:not(.login-page) .nh-panel-head p,
    body:not(.login-page) .nh-page .backup-panel-header p,
    body:not(.login-page) .nh-page .rel-section-head p,
    body:not(.login-page) .nh-page .spare-form-section-head p {
        max-width: none !important;
    }

    body:not(.login-page) .nh-panel-grid {
        grid-template-columns: 1fr !important;
    }

    body:not(.login-page) .nh-action-bar {
        display: grid !important;
        grid-template-columns: 1fr !important;
    }

    body:not(.login-page) .nh-action-bar .btn {
        width: 100% !important;
        justify-content: center !important;
    }

    body:not(.login-page) .nh-workflow-note {
        display: none !important;
    }
}

/* ============================================
   MOBILE FLOATING NAV
   ============================================ */
@media (max-width: 768px) {
    body:not(.login-page) .mobile-nav {
        --mobile-nav-panel-width: min(216px, calc(100vw - 18px));
        --mobile-nav-panel-pad: 12px;
        position: fixed !important;
        left: auto !important;
        right: 16px !important;
        bottom: calc(18px + env(safe-area-inset-bottom)) !important;
        width: auto !important;
        min-width: 0 !important;
        height: auto !important;
        padding: 0 !important;
        padding-bottom: 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        display: flex !important;
        flex-direction: column-reverse !important;
        align-items: flex-end !important;
        justify-content: flex-start !important;
        gap: 10px !important;
        pointer-events: none !important;
        z-index: 1105 !important;
    }

    body:not(.login-page) .mobile-nav.is-open::before {
        content: '' !important;
        position: absolute !important;
        right: 0 !important;
        bottom: 52px !important;
        width: var(--mobile-nav-panel-width) !important;
        height: calc(100% - 42px) !important;
        border-radius: 22px !important;
        background: rgba(2, 8, 23, 0.58) !important;
        border: 1px solid rgba(226, 232, 240, 0.12) !important;
        box-shadow: 0 22px 46px rgba(0, 0, 0, 0.42) !important;
        backdrop-filter: blur(10px) saturate(1.08) !important;
        -webkit-backdrop-filter: blur(10px) saturate(1.08) !important;
        pointer-events: none !important;
        z-index: 0 !important;
    }

    body:not(.login-page) .mobile-nav-toggle {
        position: relative !important;
        width: 58px !important;
        height: 58px !important;
        border: 1px solid rgba(180, 201, 245, 0.26) !important;
        border-radius: 999px !important;
        color: #fff !important;
        background: linear-gradient(135deg, #1b4a99 0%, #4334c9 58%, #6530c9 100%) !important;
        box-shadow: 0 12px 26px rgba(35, 64, 173, 0.28), 0 0 0 5px rgba(88, 80, 236, 0.08) !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        cursor: pointer !important;
        pointer-events: auto !important;
        z-index: 2 !important;
        transition: transform 260ms cubic-bezier(0.22, 1, 0.36, 1),
            box-shadow 260ms ease,
            background 260ms ease !important;
    }

    body:not(.login-page) .mobile-nav-toggle:active {
        transform: scale(0.94) !important;
    }

    body:not(.login-page) .mobile-nav.is-open .mobile-nav-toggle {
        transform: rotate(90deg) !important;
        box-shadow: 0 14px 30px rgba(35, 64, 173, 0.34), 0 0 0 6px rgba(124, 58, 237, 0.10) !important;
    }

    body:not(.login-page) .mobile-nav-toggle-icon {
        position: absolute !important;
        inset: 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        transition: opacity 180ms ease, transform 260ms cubic-bezier(0.22, 1, 0.36, 1) !important;
    }

    body:not(.login-page) .mobile-nav-toggle-icon--close {
        opacity: 0 !important;
        transform: scale(0.62) rotate(-45deg) !important;
    }

    body:not(.login-page) .mobile-nav.is-open .mobile-nav-toggle-icon--open {
        opacity: 0 !important;
        transform: scale(0.62) rotate(45deg) !important;
    }

    body:not(.login-page) .mobile-nav.is-open .mobile-nav-toggle-icon--close {
        opacity: 1 !important;
        transform: scale(1) rotate(-90deg) !important;
    }

    body:not(.login-page) .mobile-nav a {
        position: relative !important;
        width: calc(var(--mobile-nav-panel-width) - 24px) !important;
        min-height: 48px !important;
        box-sizing: border-box !important;
        margin-right: var(--mobile-nav-panel-pad) !important;
        flex: 0 0 auto !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 10px !important;
        padding: 8px 12px !important;
        border-radius: 16px !important;
        border: 1px solid rgba(180, 201, 245, 0.25) !important;
        color: #f8fbff !important;
        background: linear-gradient(135deg, rgba(3, 11, 27, 0.98), rgba(10, 31, 67, 0.98)) !important;
        box-shadow: 0 14px 30px rgba(0, 0, 0, 0.40), inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
        text-shadow: 0 1px 1px rgba(0, 0, 0, 0.45) !important;
        font-size: 12px !important;
        font-weight: 800 !important;
        line-height: 1.1 !important;
        text-align: left !important;
        opacity: 0 !important;
        visibility: hidden !important;
        transform: translateY(14px) scale(0.92) !important;
        transform-origin: right bottom !important;
        pointer-events: none !important;
        z-index: 1 !important;
        transition: opacity 180ms ease,
            visibility 180ms ease,
            transform 300ms cubic-bezier(0.22, 1, 0.36, 1),
            border-color 220ms ease,
            background 220ms ease !important;
    }

    body:not(.login-page) .mobile-nav.is-open a {
        opacity: 1 !important;
        visibility: visible !important;
        transform: translateY(0) scale(1) !important;
        pointer-events: auto !important;
    }

    body:not(.login-page) .mobile-nav.is-open a:nth-of-type(1) { transition-delay: 20ms !important; }
    body:not(.login-page) .mobile-nav.is-open a:nth-of-type(2) { transition-delay: 55ms !important; }
    body:not(.login-page) .mobile-nav.is-open a:nth-of-type(3) { transition-delay: 90ms !important; }
    body:not(.login-page) .mobile-nav.is-open a:nth-of-type(4) { transition-delay: 125ms !important; }

    body:not(.login-page) .mobile-nav a .nav-icon,
    body:not(.login-page) .mobile-nav a span:first-child:not(.nav-icon) {
        width: 34px !important;
        height: 34px !important;
        flex: 0 0 34px !important;
        border-radius: 12px !important;
        background: rgba(226, 232, 240, 0.16) !important;
        color: #ffffff !important;
        box-shadow: inset 0 0 0 1px rgba(226, 232, 240, 0.12) !important;
    }

    body:not(.login-page) .mobile-nav a.active {
        color: #fff !important;
        border-color: rgba(124, 58, 237, 0.58) !important;
        background: linear-gradient(135deg, rgba(37, 99, 235, 0.98), rgba(91, 55, 219, 0.98)) !important;
        box-shadow: 0 14px 32px rgba(37, 99, 235, 0.30), inset 0 1px 0 rgba(255, 255, 255, 0.14) !important;
    }

    body:not(.login-page) .mobile-nav a.active .nav-icon,
    body:not(.login-page) .mobile-nav a.active span:first-child:not(.nav-icon) {
        background: rgba(255, 255, 255, 0.16) !important;
        color: #fff !important;
    }

    html:not(.dark) body:not(.login-page) .mobile-nav.is-open::before {
        background: linear-gradient(180deg, rgba(13, 47, 103, 0.92), rgba(10, 39, 85, 0.86)) !important;
        border-color: rgba(214, 228, 255, 0.18) !important;
        box-shadow: 0 22px 46px rgba(10, 39, 85, 0.28), 0 8px 18px rgba(15, 23, 42, 0.12) !important;
    }

    html:not(.dark) body:not(.login-page) .mobile-nav-toggle {
        background: linear-gradient(135deg, #0d2f67 0%, #1b4a99 58%, #4334c9 100%) !important;
        border-color: rgba(214, 228, 255, 0.24) !important;
        box-shadow: 0 12px 26px rgba(10, 39, 85, 0.28), 0 0 0 5px rgba(13, 47, 103, 0.10) !important;
    }

    html:not(.dark) body:not(.login-page) .mobile-nav a {
        background: linear-gradient(135deg, rgba(13, 47, 103, 0.98), rgba(10, 39, 85, 0.98)) !important;
        border-color: rgba(214, 228, 255, 0.22) !important;
        color: var(--header-text) !important;
        box-shadow: 0 12px 24px rgba(10, 39, 85, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
        text-shadow: none !important;
    }

    html:not(.dark) body:not(.login-page) .mobile-nav a .nav-icon,
    html:not(.dark) body:not(.login-page) .mobile-nav a span:first-child:not(.nav-icon) {
        background: rgba(255, 255, 255, 0.14) !important;
        box-shadow: inset 0 0 0 1px rgba(214, 228, 255, 0.18) !important;
        color: var(--header-text) !important;
    }

    html:not(.dark) body:not(.login-page) .mobile-nav a.active {
        background: linear-gradient(135deg, #1b4a99 0%, #2d58bf 54%, #5b37db 100%) !important;
        border-color: rgba(214, 228, 255, 0.28) !important;
        box-shadow: 0 14px 30px rgba(13, 47, 103, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.16) !important;
    }

    html.dark body:not(.login-page) .mobile-nav a {
        background: linear-gradient(135deg, rgba(2, 8, 23, 0.99), rgba(8, 25, 56, 0.98)) !important;
        border-color: rgba(226, 232, 240, 0.20) !important;
    }
}

/* Landscape tablet */
@media (max-width: 900px) and (orientation: landscape) {
    .filters-form {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .filters-form label { font-size: 11px; }
    .filters-form input, .filters-form select { width: 100%; }
    .filters-mobile-header { margin-bottom: 6px; }
    .filters-toggle { padding: 6px 10px; font-size: 11px; }
    .filters-form .btn { width: 100%; justify-content: center; }

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

    .backup-panel { padding: 16px; }
    .panel-btns .btn { width: 100%; justify-content: center; }
}

/* Small phones */
@media (max-width: 480px) {
    .topbar-title { display: none; }
    .topbar-logo { width: 34px; height: 34px; flex-basis: 34px; font-size: 0; }
    .site-indicator { margin-left: 0; max-width: none; }
    .site-switcher-caret { display: none; }
    .page-header h2, .dashboard-header h2 { font-size: 22px; }
    .stat-icon { width: 36px; height: 36px; font-size: 18px; }
    .stat-info h3 { font-size: 20px; }
    .fotos-grid, .fotos-gallery { grid-template-columns: 1fr; }
    .login-nav-inner { padding: 8px 10px; }
    .login-nav-brand strong { font-size: 19px; }
    .login-nav-btn { padding: 7px 10px; font-size: 11px; }
    .login-nav-btn-primary { min-width: 74px; }
    .login-nav-btn-ghost { min-width: 66px; }
    .login-shell { padding: 10px 12px calc(80px + env(safe-area-inset-bottom)); min-height: calc(100svh - var(--mobile-nav-height, 66px)); }
    .login-card { padding: 10px 0 0; border-radius: 0; min-height: auto; }
    .login-brand .brand-icon,
    .login-brand > span:first-child { width: 38px; height: 38px; font-size: 13px; }
    .login-brand h2 { font-size: 23px; }
    .login-card h3 { font-size: 33px; }
    .login-card .form-control { min-height: 48px; font-size: 16px; border-radius: 11px; }
    .login-actions .btn { min-height: 50px; font-size: 17px; border-radius: 11px; }
    .info-login { border-radius: 11px; }
    .login-mobile-marketing { border-radius: 12px; padding: 9px 10px; }
    .login-mobile-marketing-title { font-size: 12px; }
    .login-mobile-marketing-subtitle { font-size: 11px; margin-bottom: 8px; }
    .login-mobile-marketing-list { gap: 6px; }
    .login-mobile-marketing-list li { border-radius: 9px; padding: 7px; font-size: 11px; grid-template-columns: 18px 1fr; }
    .login-mobile-marketing-bullet { width: 14px; height: 14px; }
    .login-mobile-marketing-bullet::after { left: 4px; top: 3px; width: 5px; height: 3px; }
    .login-showcase h1 { font-size: clamp(28px, 10vw, 38px); }
    .login-showcase > p { font-size: 15px; }
    .login-stats-inner { grid-template-columns: 1fr; }
    .login-cta { font-size: 14px; width: 100%; justify-content: center; display: inline-flex; }
    .login-interactive-inner { padding: 28px 10px 36px; }
    .login-filter-btn { width: calc(50% - 4px); justify-content: center; display: inline-flex; flex: 1 1 calc(50% - 4px); }
    .login-feature-icon { width: 42px; height: 42px; }
    .login-feature-icon svg { width: 20px; height: 20px; }
    .login-marquee { --marquee-speed: 18s; }
    .login-mobile-cue { left: 50%; right: auto; bottom: calc(8px + env(safe-area-inset-bottom)); min-width: 150px; padding: 7px 12px; min-height: 38px; font-size: 11px; }
    .login-mobile-cue span { display: inline; }
    .login-help-inner,
    .login-contact-inner,
    .login-faq-inner { padding: 28px 10px; }
    .login-help-item { padding: 12px; }
    .login-faq-item { padding: 12px; }
    .login-contact-card { padding: 14px; }

    .shortcuts-body { grid-template-columns: 1fr; }
}

/* ---- Charts Responsive ---- */
@media (max-width: 768px) {
    .charts-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    .chart-body { height: 220px; }
    .chart-header { padding: 16px 16px 0; }
    .chart-body { padding: 12px 16px 16px; }
}

/* ---- Page Header Actions Responsive ---- */
@media (max-width: 768px) {
    .page-header-actions {
        width: 100%;
        justify-content: flex-end;
    }
    .page-header-actions .btn-text { display: none; }
}

/* ---- Grid View Responsive ---- */
@media (max-width: 600px) {
    .equip-grid-view {
        grid-template-columns: 1fr;
    }
}

/* ---- Batch Toolbar Responsive ---- */
@media (max-width: 768px) {
    .batch-toolbar {
        left: 12px !important;
        right: 86px !important;
        bottom: calc(-150px - env(safe-area-inset-bottom)) !important;
        transform: none !important;
        z-index: 1095 !important;
        opacity: 0 !important;
        pointer-events: none !important;
        transition: bottom 280ms cubic-bezier(0.22, 1, 0.36, 1), opacity 180ms ease !important;
    }

    .batch-toolbar.active {
        bottom: calc(14px + env(safe-area-inset-bottom)) !important;
        opacity: 1 !important;
        pointer-events: auto !important;
    }

    .batch-toolbar-inner {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        align-items: center !important;
        gap: 8px !important;
        width: 100% !important;
        padding: 10px !important;
        border-radius: 18px !important;
        border: 1px solid rgba(124, 58, 237, 0.34) !important;
        background: linear-gradient(145deg, rgba(11, 39, 84, 0.96), rgba(22, 49, 100, 0.94)) !important;
        box-shadow: 0 16px 34px rgba(3, 13, 31, 0.34), 0 0 0 1px rgba(124, 58, 237, 0.14) !important;
        backdrop-filter: blur(14px) !important;
        -webkit-backdrop-filter: blur(14px) !important;
    }

    .batch-count {
        display: inline-flex !important;
        align-items: center !important;
        min-width: 0 !important;
        min-height: 30px !important;
        padding: 0 10px !important;
        border-radius: 999px !important;
        color: #e8edff !important;
        background: rgba(124, 58, 237, 0.22) !important;
        font-size: 11px !important;
        font-weight: 850 !important;
        white-space: nowrap !important;
    }

    .batch-toolbar-inner > .btn-ghost {
        grid-column: 2 !important;
        grid-row: 1 !important;
        min-width: 0 !important;
        height: 30px !important;
        min-height: 30px !important;
        padding: 0 10px !important;
        border-radius: 999px !important;
        color: #d9e7ff !important;
        border-color: rgba(198, 216, 248, 0.24) !important;
        background: rgba(198, 216, 248, 0.10) !important;
        font-size: 11px !important;
        font-weight: 800 !important;
        box-shadow: none !important;
    }

    .batch-actions {
        grid-column: 1 / -1 !important;
        display: grid !important;
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
        gap: 6px !important;
        width: 100% !important;
    }

    .batch-actions .btn {
        width: 100% !important;
        min-width: 0 !important;
        min-height: 36px !important;
        height: 36px !important;
        padding: 0 6px !important;
        border-radius: 11px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 4px !important;
        font-size: 10px !important;
        font-weight: 900 !important;
        letter-spacing: 0 !important;
        line-height: 1 !important;
        box-shadow: none !important;
        overflow: hidden !important;
    }

    .batch-actions .btn svg {
        width: 13px !important;
        height: 13px !important;
        flex: 0 0 auto !important;
    }

    .batch-actions .btn-success {
        color: #d1fae5 !important;
        border-color: rgba(34, 197, 94, 0.48) !important;
        background: rgba(22, 163, 74, 0.18) !important;
    }

    .batch-actions .btn-warning {
        color: #fde68a !important;
        border-color: rgba(245, 158, 11, 0.52) !important;
        background: rgba(245, 158, 11, 0.18) !important;
    }

    .batch-actions .btn-secondary {
        color: #dbeafe !important;
        border-color: rgba(96, 165, 250, 0.42) !important;
        background: rgba(37, 99, 235, 0.16) !important;
    }

    .batch-actions .btn-danger {
        color: #fecaca !important;
        border-color: rgba(248, 113, 113, 0.50) !important;
        background: rgba(239, 68, 68, 0.18) !important;
    }

    @media (max-width: 360px) {
        .batch-toolbar {
            left: 10px !important;
            right: 78px !important;
        }

        .batch-toolbar-inner {
            padding: 8px !important;
        }

        .batch-count,
        .batch-toolbar-inner > .btn-ghost {
            font-size: 10px !important;
            padding: 0 8px !important;
        }

        .batch-actions .btn {
            font-size: 0 !important;
            gap: 0 !important;
        }
    }

    .col-check { width: 32px; }
}

/* ---- Shortcuts Modal Responsive ---- */
@media (max-width: 768px) {
    .shortcuts-body {
        grid-template-columns: 1fr;
        gap: 16px;
    }
}

/* ---- Home Page Responsive ---- */
@media (max-width: 768px) {
    .home-hero {
        flex-direction: column;
        text-align: center;
        padding: 24px 20px;
    }
    .home-hero h2 { font-size: 22px; }
    .home-stats {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }
    .home-stat-card { padding: 14px 12px; gap: 10px; }
    .home-stat-value { font-size: 20px; }
    .home-types {
        grid-template-columns: 1fr;
    }
    .home-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }
}
@media (max-width: 480px) {
    .home-stats { grid-template-columns: 1fr; }
    .home-stat-card { flex-direction: row; }
}

/* ---- Analytics Dashboard Responsive ---- */
@media (max-width: 1200px) {
    .kpi-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media (max-width: 768px) {
    .dash-hero {
        flex-direction: column;
        gap: 12px;
    }
    .dash-hero-actions.dash-hero-actions-desktop {
        display: none;
    }
    .dash-bottom-actions {
        display: flex;
    }
    .dash-tabs {
        gap: 4px;
        padding: 4px;
        border-radius: 12px;
        margin-bottom: 20px;
    }
    .dash-tab {
        padding: 8px 10px;
        font-size: 12px;
        gap: 5px;
        border-radius: 8px;
    }
    .dash-tab svg { width: 14px; height: 14px; }
    .dash-tab span:not(.dash-tab-count) { display: inline; }
    .dash-tab-count {
        min-width: 20px;
        height: 18px;
        padding: 0 5px;
        font-size: 10px;
    }
    .kpi-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }
    .kpi-card { padding: 14px 12px; }
    .kpi-value { font-size: 20px; }
    .kpi-icon { width: 36px; height: 36px; }
    .kpi-icon svg { width: 20px; height: 20px; }
    .charts-grid,
    .dash-dual-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    .chart-card {
        min-width: 0;
        overflow: hidden;
    }
    .master-health-grid {
        grid-template-columns: 1fr;
    }
    .tipo-detail-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .operation-legend { gap: 10px; flex-wrap: wrap; }
    .operation-pct { font-size: 22px; }
    .pendencia-text { max-width: 180px; }
    .dash-section {
        padding: 16px;
        overflow-x: hidden;
    }
    .section-header {
        flex-wrap: wrap;
        gap: 8px;
    }
    .table-responsive {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        max-width: 100%;
    }
}
@media (max-width: 480px) {
    .kpi-grid { grid-template-columns: 1fr; }
    .tipo-detail-grid { grid-template-columns: 1fr; }
    .operation-bar { padding: 16px; }
    .dash-section { padding: 14px; }
    .dash-hero-actions .btn { flex: 1 1 100%; }
}

/* ---- Analytics: pendências e atividades no mobile ---- */
@media (max-width: 768px) {
    .pendencia-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
    .pendencia-left { flex-shrink: 1; }
    .pendencia-right { text-align: left; width: 100%; }
    .pendencia-text {
        max-width: 100%;
        white-space: normal;
        -webkit-line-clamp: 2;
        line-clamp: 2;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
    .activity-main {
        flex-wrap: wrap;
    }
    .activity-meta {
        flex-wrap: wrap;
    }
    .activity-time {
        margin-left: 0;
    }

    .hud-hero {
        grid-template-columns: 1fr;
        padding: 16px;
        gap: 14px;
    }

    .hud-hero-orb {
        display: none;
    }

    .hud-hero-main {
        padding: 10px;
    }

    .hud-hero-side {
        display: block;
    }

    .hud-side-card {
        padding: 9px;
        gap: 8px;
    }

    .hud-side-head {
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
    }

    .hud-side-counter {
        font-size: 11px;
    }

    .hud-side-tabs {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 6px;
    }

    .hud-side-tab {
        min-height: 34px;
        padding: 6px 7px;
        font-size: 10px;
    }

    .hud-hero h2 {
        font-size: clamp(28px, 8.2vw, 40px);
        line-height: 1.05;
        margin: 6px 0 4px;
    }

    .hud-hero p {
        font-size: 14px;
    }

    .hud-hero-pills {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 8px;
    }

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

    .hud-analytic-card {
        min-height: 0;
    }

    .hud-status-bars li {
        grid-template-columns: 34px 1fr 32px;
    }

    .hud-sparkline {
        height: 58px;
    }

    .hud-hero-pill {
        min-width: 0;
    }

    .hud-hero-intel {
        padding: 10px;
    }

    .hud-hero-intel p {
        font-size: 12px;
    }

    .hud-hero-actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .hud-hero-action {
        width: 100%;
        justify-content: center;
    }

    .hud-hero-kpi-panel {
        padding: 10px;
        border-radius: 12px;
        gap: 8px;
    }

    .hud-hero-kpi-head {
        flex-direction: column;
        align-items: flex-start;
        gap: 3px;
    }

    .hud-hero-kpi-head small {
        font-size: 10px;
    }

    .hud-hero-tools {
        width: 100%;
        margin-top: 8px;
    }

    .hud-notify-btn {
        width: 100%;
        justify-content: space-between;
        border-radius: 10px;
    }

    .hud-notify-label {
        font-size: 12px;
    }

    .hud-notify-panel {
        width: 100%;
        max-height: 300px;
        left: 0;
        right: auto;
    }

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

    .hud-kpi-mini {
        padding: 8px 9px;
    }

    .hud-kpi-mini strong {
        font-size: 23px;
    }

    .hud-map-panel {
        min-height: 230px;
    }

    .hud-brazil-map {
        min-height: 190px;
    }

    .hud-grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .hud-tree-hover-zone {
        display: none;
    }

    .hud-tree-sidebar {
        position: static;
        right: auto;
        width: 100%;
        height: auto;
        max-height: 300px;
        margin-top: 12px;
        border-radius: 12px;
        box-shadow: var(--shadow-xs);
    }

    .hud-filters .filters-form {
        grid-template-columns: 1fr !important;
        gap: 10px;
    }

    .hud-filters .filter-actions {
        width: 100%;
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

    .hud-updates {
        padding: 12px;
        margin-bottom: 12px;
    }

    .hud-updates-head {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .hud-updates-grid {
        grid-template-columns: 1fr;
    }

    .hud-update-card {
        min-height: 0;
    }

    .recent-updates-grid {
        padding: 8px 10px 12px !important;
        gap: 8px !important;
    }

    .recent-updates-grid .ru-card {
        grid-template-columns: minmax(0, 1fr) max-content !important;
        grid-template-areas:
            "badges action"
            "content action" !important;
        align-items: center !important;
        gap: 7px 8px !important;
        padding: 10px 8px 10px 10px !important;
        border-radius: 10px !important;
        border-left-width: 3px !important;
    }

    .recent-updates-grid .ru-card-left {
        grid-area: badges !important;
        flex-direction: row !important;
        flex-wrap: wrap !important;
        align-items: center !important;
        gap: 4px !important;
        min-width: 0 !important;
    }

    .recent-updates-grid .ru-type-chip,
    .recent-updates-grid .ru-status-pill {
        max-width: 86px !important;
        min-height: 18px !important;
        padding: 2px 6px !important;
        font-size: 9px !important;
        line-height: 1 !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    .recent-updates-grid .ru-card-center {
        grid-area: content !important;
        gap: 3px !important;
        min-width: 0 !important;
    }

    .recent-updates-grid .ru-name {
        font-size: 13px !important;
        line-height: 1.15 !important;
        font-weight: 850 !important;
        white-space: normal !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    .recent-updates-grid .ru-meta {
        font-size: 10px !important;
        line-height: 1.25 !important;
        white-space: normal !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    .recent-updates-grid .ru-card-actions {
        grid-area: action !important;
        align-self: stretch !important;
        justify-self: end !important;
        min-width: 78px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 6px !important;
    }

    .hud-card {
        min-height: 0;
    }

    .hud-card-brand {
        width: 60px;
        height: 38px;
    }

    .hud-card-stats {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 6px;
    }

    .hud-card-stats div {
        padding: 8px 4px;
    }

    .hud-card-stats strong {
        font-size: 14px;
    }

    .hud-card-stats span {
        font-size: 10px;
    }

    .hud-card-actions {
        grid-template-columns: 1fr;
    }

    .site-picker-toolbar {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .site-picker-grid {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .site-picker-card {
        padding: 12px;
    }

    .site-picker-card__head {
        flex-direction: column;
        align-items: flex-start;
    }

    body.tech-mode .hud-hero {
        padding: 12px;
        gap: 10px;
    }

    body.tech-mode .hud-hero-main {
        padding: 0;
    }

    body.tech-mode .hud-chip {
        font-size: 10px;
        padding: 4px 8px;
    }

    body.tech-mode .hud-hero h2 {
        font-size: clamp(24px, 7.5vw, 32px);
        margin: 4px 0;
    }

    body.tech-mode .hud-hero p {
        font-size: 13px;
        margin-bottom: 6px;
    }

    body.tech-mode .hud-hero-pills {
        grid-template-columns: 1fr;
        gap: 6px;
    }

    body.tech-mode .hud-content-layout {
        margin-top: 10px;
    }

    body.tech-mode .hud-grid {
        gap: 10px;
    }

    body.tech-mode .hud-card {
        border-radius: 12px;
    }

    body.tech-mode .hud-card-actions {
        grid-template-columns: 1fr;
    }

    body.tech-mode .hud-card-actions .btn {
        width: 100%;
    }
}
/* ============================================
   Design System Mobile Overrides v5.1
   ============================================ */
@media (max-width: 360px) {
    .stats-grid,
    .kpi-grid,
    .backup-reports-grid,
    .equip-grid-view,
    .charts-grid {
        grid-template-columns: 1fr !important;
    }

    .table-stacked tbody tr {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .table-stacked tbody td.actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .table-stacked tbody td.actions .btn {
        width: 100%;
    }

    .dash-tab {
        padding: 8px 6px;
        font-size: 11px;
    }

    .dash-tab-count {
        min-width: 18px;
        height: 18px;
        font-size: 10px;
    }

    .filters-form .btn,
    .filters-equipamentos .filter-actions .btn,
    .panel-btns-row .btn,
    .hud-card-actions .btn {
        width: 100%;
        justify-content: center;
    }

    /* Dashboard list (mobile <=360): manter nome/pai na mesma linha e acoes horizontais */
    #dashboardEquipViewTable .table-stacked tbody tr {
        grid-template-columns: minmax(0, 1fr) auto auto auto !important;
        grid-template-areas:
            "name status status status"
            "codigo fotos actions actions" !important;
        gap: 6px 8px !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions {
        display: flex !important;
        grid-template-columns: none !important;
        align-items: center !important;
        justify-content: flex-end !important;
        gap: 4px !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions .btn {
        width: 32px !important;
        min-width: 32px !important;
        height: 26px !important;
    }
}

/* ============================================
   MOBILE LOGIN FORCE OVERRIDES (high priority)
   ============================================ */
@media (max-width: 768px) {
    .login-page,
    body.login-page {
        background: #ffffff !important;
    }
    .login-page::before,
    .login-page::after,
    .login-bg-grid,
    .login-particles {
        display: none !important;
        background: none !important;
    }

    .login-nav {
        position: static !important;
        top: auto !important;
        background: #ffffff !important;
        border-bottom: 1px solid #e4ebf7 !important;
    }

    .login-shell {
        max-width: 440px !important;
        margin: 0 auto !important;
        padding: calc(var(--mobile-nav-height, 64px) + 18px) 14px 12px !important;
        min-height: auto !important;
        display: block !important;
        background: #ffffff !important;
    }

    .login-card {
        max-width: 420px !important;
        margin: 0 auto 8px !important;
        width: 100% !important;
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
    }
    .login-card::before {
        display: none !important;
        content: none !important;
        background: none !important;
    }
    .login-card .login-brand,
    .login-card-subtitle {
        display: none !important;
    }

    .login-mobile-marketing {
        border: 1px solid #d8e3f3 !important;
        background: #fbfdff !important;
        box-shadow: 0 5px 12px rgba(16, 34, 72, 0.07) !important;
    }
    .login-mobile-marketing-title {
        color: #29486f !important;
    }
    .login-mobile-marketing-subtitle {
        color: #587195 !important;
    }
    .login-mobile-marketing-list li {
        background: #f7faff !important;
        border-color: #dce7f6 !important;
    }

    .login-mobile-cue {
        left: 50% !important;
        right: auto !important;
        bottom: calc(8px + env(safe-area-inset-bottom)) !important;
        transform: translateX(-50%) !important;
        min-height: 38px !important;
        min-width: 150px !important;
        padding: 7px 12px !important;
        font-size: 11px !important;
        border-radius: 999px !important;
        border-color: rgba(68, 90, 181, 0.58) !important;
        background: linear-gradient(135deg, rgba(36, 78, 196, 0.86) 0%, rgba(74, 61, 200, 0.86) 100%) !important;
        box-shadow: 0 7px 14px rgba(35, 52, 125, 0.28) !important;
        animation: loginMobileCuePulseSoft 2s ease-in-out infinite !important;
    }
}

/* ============================================
   Dashboard + Analytics (Equipamentos) Mobile Final
   ============================================ */
@media (max-width: 768px) {
    /* Dashboard home: lista de equipamentos compacta e consistente */
    #dashboardEquipViewTable .table-stacked tbody tr {
        grid-template-columns: minmax(0, 1fr) auto auto auto !important;
        grid-template-areas:
            "name status status status"
            "codigo fotos actions actions" !important;
        align-items: center !important;
        gap: 8px 10px !important;
        padding: 11px 12px !important;
        margin-bottom: 7px !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(1),
    #dashboardEquipViewTable .table-stacked tbody td:nth-child(5),
    #dashboardEquipViewTable .table-stacked tbody td:nth-child(7) {
        display: none !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.equip-name-cell,
    #dashboardEquipViewTable .table-stacked tbody td:nth-child(2) {
        grid-area: name !important;
        display: block !important;
        justify-self: start !important;
        text-align: left !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        min-width: 0 !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.equip-name-cell .equip-name-line {
        display: block !important;
        font-size: 0.99rem !important;
        font-weight: 800 !important;
        line-height: 1.15 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(3) {
        grid-area: codigo !important;
        display: block !important;
        text-align: left !important;
        color: var(--muted) !important;
        font-size: 12px !important;
        font-weight: 700 !important;
        line-height: 1.15 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        min-width: 0 !important;
        padding: 0 !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(4) {
        grid-area: status !important;
        display: flex !important;
        justify-content: flex-end !important;
        align-items: center !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(6) {
        grid-area: fotos !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        gap: 4px !important;
        color: var(--muted) !important;
        font-size: 12px !important;
        font-weight: 800 !important;
        line-height: 1 !important;
        min-width: 48px !important;
        padding: 0 !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions {
        grid-area: actions !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-end !important;
        gap: 6px !important;
        min-width: 88px !important;
        padding: 0 !important;
        margin: 0 !important;
        border-top: 0 !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions .btn {
        width: 42px !important;
        min-width: 42px !important;
        height: 32px !important;
        min-height: 32px !important;
        padding: 0 !important;
        border-radius: 9px !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions .btn .btn-text {
        display: none !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td.actions .btn svg {
        width: 15px !important;
        height: 15px !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(2)::before,
    #dashboardEquipViewTable .table-stacked tbody td:nth-child(3)::before,
    #dashboardEquipViewTable .table-stacked tbody td:nth-child(4)::before,
    #dashboardEquipViewTable .table-stacked tbody td.actions::before {
        display: none !important;
    }

    #dashboardEquipViewTable .table-stacked tbody td:nth-child(6)::before {
        content: 'FOTOS' !important;
        display: inline-block !important;
        font-size: 9px !important;
        font-weight: 700 !important;
        letter-spacing: 0.08em !important;
        margin-right: 4px !important;
        opacity: 0.72 !important;
    }

    #dashboardEquipViewTable .table-stacked tbody tr.dashboard-empty-row {
        display: block !important;
        padding: 0 !important;
        margin-bottom: 10px !important;
        border: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
    }

    #dashboardEquipViewTable .table-stacked tbody tr.dashboard-empty-row td {
        display: block !important;
        padding: 0 !important;
        margin: 0 !important;
        border: 0 !important;
        text-align: center !important;
    }

    #dashboardEquipViewTable .table-stacked tbody tr.dashboard-empty-row td::before {
        content: none !important;
        display: none !important;
    }

    #lista-equipamentos .dashboard-equip-empty {
        min-height: 190px !important;
        padding: 26px 18px !important;
    }

    /* Analytics (aba Equipamentos): críticos mais legível no mobile */
    #tab-equipamentos .dash-eq-criticos-table.table-stacked tbody tr {
        grid-template-columns: auto minmax(0, 1fr) auto !important;
        grid-template-areas:
            "tipo nome nome"
            "codigo master atualizado"
            "pendencia pendencia pendencia"
            "acoes acoes acoes" !important;
        gap: 8px 10px !important;
        padding: 12px !important;
        margin-bottom: 8px !important;
        border-radius: 12px !important;
    }

    #tab-equipamentos .dash-eq-criticos-table .eqc-tipo {
        grid-area: tipo !important;
        padding: 0 !important;
    }

    #tab-equipamentos .dash-eq-criticos-table .eqc-nome {
        grid-area: nome !important;
        padding: 0 !important;
        min-width: 0 !important;
        text-align: left !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    #tab-equipamentos .dash-eq-criticos-table .eqc-codigo,
    #tab-equipamentos .dash-eq-criticos-table .eqc-master,
    #tab-equipamentos .dash-eq-criticos-table .eqc-atualizado {
        padding: 0 !important;
        min-width: 0 !important;
        font-size: 12px !important;
        color: var(--muted) !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    #tab-equipamentos .dash-eq-criticos-table .eqc-codigo { grid-area: codigo !important; }
    #tab-equipamentos .dash-eq-criticos-table .eqc-master { grid-area: master !important; }
    #tab-equipamentos .dash-eq-criticos-table .eqc-atualizado {
        grid-area: atualizado !important;
        justify-self: end !important;
        text-align: right !important;
    }

    #tab-equipamentos .dash-eq-criticos-table .eqc-localizacao {
        display: none !important;
    }

    #tab-equipamentos .dash-eq-criticos-table .eqc-pendencia {
        grid-area: pendencia !important;
        padding: 8px 10px !important;
        border-radius: 10px !important;
        background: rgba(239, 68, 68, 0.08) !important;
        border: 1px solid rgba(239, 68, 68, 0.2) !important;
    }

    #tab-equipamentos .dash-eq-criticos-table .eqc-actions {
        grid-area: acoes !important;
        display: flex !important;
        justify-content: flex-end !important;
        gap: 8px !important;
        padding: 8px 0 0 !important;
        margin: 0 !important;
        border-top: 1px solid var(--border-light) !important;
    }

    #tab-equipamentos .dash-eq-criticos-table .eqc-actions .btn {
        min-height: 32px !important;
        padding: 0 11px !important;
    }

    #tab-equipamentos .dash-eq-criticos-table .eqc-tipo::before,
    #tab-equipamentos .dash-eq-criticos-table .eqc-nome::before,
    #tab-equipamentos .dash-eq-criticos-table .eqc-actions::before {
        display: none !important;
    }
}

@media (max-width: 380px) {
    #dashboardEquipViewTable .table-stacked tbody td.actions .btn {
        width: 38px !important;
        min-width: 38px !important;
    }

    #tab-equipamentos .dash-eq-criticos-table.table-stacked tbody tr {
        grid-template-columns: minmax(0, 1fr) auto !important;
        grid-template-areas:
            "nome tipo"
            "codigo atualizado"
            "master master"
            "pendencia pendencia"
            "acoes acoes" !important;
    }
}

/* Equipamentos (mobile): manter 3 botoes de acao na mesma linha */
@media (max-width: 768px) {
    #viewTable .table-stacked tbody td.actions {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 7px !important;
        align-items: center !important;
        justify-content: stretch !important;
    }

    #viewTable .table-stacked tbody td.actions .btn {
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        justify-content: center !important;
    }
}

@media (max-width: 360px) {
    #viewTable .table-stacked tbody td.actions {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 6px !important;
    }

    #viewTable .table-stacked tbody td.actions .btn {
        width: 100% !important;
        min-width: 0 !important;
    }
}

/* ============================================
   MOBILE LOGIN FINAL LOCK
   ============================================ */
@media (max-width: 768px) {
    /* remove any remaining fade/overlay */
    .login-page,
    body.login-page,
    .login-shell,
    .login-card {
        background: #ffffff !important;
    }
    .login-page::before,
    .login-page::after,
    .login-shell::before,
    .login-shell::after,
    .login-card::before,
    .login-card::after {
        content: none !important;
        display: none !important;
        opacity: 0 !important;
        background: none !important;
        box-shadow: none !important;
        filter: none !important;
    }

    /* header fixed on mobile (entire page) */
    .login-nav,
    .login-page.scrolled .login-nav {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        inset: auto !important;
        width: 100% !important;
        z-index: 30 !important;
        transform: none !important;
        background: #ffffff !important;
        border-bottom: 1px solid #e4ebf7 !important;
    }
    .login-page:not(.scrolled) .login-nav {
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
        transform: translate3d(0, -18px, 0) scale(0.985) !important;
        filter: blur(8px) !important;
        transition:
            opacity 340ms ease,
            transform 420ms cubic-bezier(0.22, 0.61, 0.36, 1),
            filter 360ms ease,
            visibility 0ms linear 420ms !important;
    }
    .login-page.scrolled .login-nav {
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        transform: translate3d(0, 0, 0) scale(1) !important;
        filter: blur(0) !important;
        animation: loginMobileHeaderReveal 560ms cubic-bezier(0.18, 0.84, 0.28, 1) both !important;
        transition:
            opacity 300ms ease,
            transform 460ms cubic-bezier(0.18, 0.84, 0.28, 1),
            filter 340ms ease,
            visibility 0ms linear 0ms !important;
    }
    @keyframes loginMobileHeaderReveal {
        0% {
            opacity: 0;
            transform: translate3d(0, -18px, 0) scale(0.985);
            filter: blur(8px);
        }
        62% {
            opacity: 1;
            transform: translate3d(0, 2px, 0) scale(1.006);
            filter: blur(0);
        }
        100% {
            opacity: 1;
            transform: translate3d(0, 0, 0) scale(1);
            filter: blur(0);
        }
    }
    .login-nav-inner {
        max-width: 440px !important;
        margin: 0 auto !important;
    }
    .login-nav-btn-primary {
        max-width: 96px !important;
        transform-origin: center !important;
        transition:
            opacity 420ms ease,
            transform 480ms cubic-bezier(0.22, 0.61, 0.36, 1),
            max-width 430ms cubic-bezier(0.22, 0.61, 0.36, 1),
            padding 410ms cubic-bezier(0.22, 0.61, 0.36, 1),
            margin 410ms cubic-bezier(0.22, 0.61, 0.36, 1),
            border-color 280ms ease,
            box-shadow 280ms ease !important;
    }
    /* hide header Login CTA while user is in login viewport */
    .login-nav-btn-primary.is-mobile-hidden {
        opacity: 0 !important;
        pointer-events: none !important;
        visibility: hidden !important;
        transform: translateY(-2px) scale(0.98) !important;
        min-width: 0 !important;
        max-width: 0 !important;
        width: 0 !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin: 0 !important;
        border-width: 0 !important;
        overflow: hidden !important;
        box-shadow: none !important;
    }

    /* cue with smoother hide animation */
    .login-mobile-cue {
        opacity: 1 !important;
        pointer-events: auto !important;
        visibility: visible !important;
        transform: translate(-50%, 0) scale(1) !important;
        filter: blur(0) !important;
        animation: loginMobileCuePulseUltraSoft 3.8s ease-in-out infinite !important;
        transition:
            opacity 460ms ease,
            transform 520ms cubic-bezier(0.22, 0.61, 0.36, 1),
            filter 420ms ease,
            visibility 0ms linear 0ms !important;
    }
    .login-mobile-cue.is-hidden {
        opacity: 0 !important;
        pointer-events: none !important;
        visibility: hidden !important;
        transform: translate(-50%, 6px) scale(0.98) !important;
        filter: blur(1px) !important;
        animation: none !important;
        transition:
            opacity 400ms ease,
            transform 460ms cubic-bezier(0.22, 0.61, 0.36, 1),
            filter 360ms ease,
            visibility 0ms linear 460ms !important;
    }
    @keyframes loginMobileCuePulseUltraSoft {
        0%, 100% { box-shadow: 0 7px 14px rgba(35, 52, 125, 0.24); }
        50% { box-shadow: 0 8px 15px rgba(35, 52, 125, 0.27); }
    }
}

/* Mobile login source of truth: moved out of login.php inline hotfix. */
@media (max-width: 768px) {
    :root { --mobile-cue-space: 62px; }

    body.login-page,
    .login-page {
        background: #ffffff !important;
    }

    body.login-page .login-bg-grid {
        display: block !important;
        opacity: 0.34 !important;
        background-size: 24px 24px !important;
        z-index: 0 !important;
    }

    body.login-page .login-particles {
        display: block !important;
        opacity: 0.95 !important;
        z-index: 0 !important;
    }

    body.login-page .login-particles span {
        opacity: 0.56 !important;
        animation: loginOrbsDrift 8.2s ease-in-out infinite !important;
    }

    body.login-page::before,
    body.login-page::after,
    body.login-page .login-card::before,
    body.login-page .login-card::after {
        display: none !important;
        content: none !important;
        opacity: 0 !important;
    }

    body.login-page .login-nav,
    body.login-page.scrolled .login-nav {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 40 !important;
        background: #ffffff !important;
        border-bottom: 1px solid #e4ebf7 !important;
    }
    body.login-page:not(.scrolled) .login-nav {
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
        transform: translate3d(0, -18px, 0) scale(0.985) !important;
        filter: blur(8px) !important;
    }
    body.login-page.scrolled .login-nav {
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        transform: translate3d(0, 0, 0) scale(1) !important;
        filter: blur(0) !important;
        animation: loginMobileHeaderReveal 560ms cubic-bezier(0.18, 0.84, 0.28, 1) both !important;
    }

    body.login-page .login-nav-inner {
        max-width: 440px !important;
        margin: 0 auto !important;
    }

    body.login-page .login-marquee,
    body.login-page .login-stats {
        display: none !important;
    }

    body.login-page .login-shell {
        display: block !important;
        max-width: 440px !important;
        margin: 0 auto !important;
        width: 100% !important;
        min-height: auto !important;
        padding: 14px 14px 12px !important;
        background: transparent !important;
        position: relative !important;
        z-index: 2 !important;
    }

    body.login-page .login-shell::before,
    body.login-page .login-shell::after {
        content: none !important;
        display: none !important;
        width: 0 !important;
        height: 0 !important;
        border: 0 !important;
        background: none !important;
        box-shadow: none !important;
        pointer-events: none !important;
        opacity: 0 !important;
        filter: none !important;
    }

    body.login-page .login-shell::before {
        left: 10px !important;
        top: 26% !important;
        animation: loginSquareDriftA 8.4s ease-in-out infinite !important;
    }

    body.login-page .login-shell::after {
        right: 12px !important;
        top: 64% !important;
        animation: loginSquareDriftB 7.6s ease-in-out infinite !important;
    }

    body.login-page .login-card {
        width: 100% !important;
        max-width: 420px !important;
        margin: 0 auto !important;
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
    }
}

/* ============================================
   MOBILE OPERATIONAL CARDS CONSISTENCY
   ============================================ */
@media (max-width: 768px) {
    #viewTable,
    #manutencaoTable,
    #manutencaoHudTable {
        overflow: visible !important;
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
    }

    #viewTable .table-stacked,
    #manutencaoTable .table-stacked,
    #manutencaoHudTable .table-stacked {
        border-collapse: separate !important;
        border-spacing: 0 !important;
    }

    #viewTable .table-stacked tbody,
    #manutencaoTable .table-stacked tbody,
    #manutencaoHudTable .table-stacked tbody {
        display: block !important;
    }

    #viewTable .table-stacked tbody tr,
    #manutencaoTable .table-stacked tbody tr,
    #manutencaoHudTable .table-stacked tbody tr {
        position: relative !important;
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 13px 16px !important;
        margin: 0 0 14px !important;
        padding: 16px !important;
        border-radius: 14px !important;
        border: 1px solid rgba(148, 163, 184, 0.22) !important;
        border-left-width: 5px !important;
        background: var(--surface) !important;
        box-shadow: 0 14px 32px rgba(15, 23, 42, 0.10) !important;
    }

    html.dark #viewTable .table-stacked tbody tr,
    html.dark #manutencaoTable .table-stacked tbody tr,
    html.dark #manutencaoHudTable .table-stacked tbody tr {
        background: linear-gradient(145deg, rgba(30, 41, 69, 0.98), rgba(23, 34, 58, 0.98)) !important;
        border-color: rgba(148, 163, 184, 0.14) !important;
        box-shadow: 0 14px 30px rgba(0, 0, 0, 0.22) !important;
    }

    #manutencaoTable .table-stacked tbody tr,
    #manutencaoHudTable .table-stacked tbody tr {
        border-left-color: var(--primary) !important;
    }

    #viewTable .table-stacked tbody td,
    #manutencaoTable .table-stacked tbody td,
    #manutencaoHudTable .table-stacked tbody td {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        justify-content: flex-start !important;
        gap: 6px !important;
        min-width: 0 !important;
        padding: 0 !important;
        border: 0 !important;
        color: var(--text) !important;
        font-size: 14px !important;
        line-height: 1.35 !important;
    }

    #viewTable .table-stacked tbody td::before,
    #manutencaoTable .table-stacked tbody td::before,
    #manutencaoHudTable .table-stacked tbody td::before {
        content: attr(data-label) !important;
        display: block !important;
        margin: 0 !important;
        font-size: 10px !important;
        font-weight: 850 !important;
        letter-spacing: 0.08em !important;
        line-height: 1.1 !important;
        text-transform: uppercase !important;
        color: var(--muted) !important;
    }

    #viewTable .table-stacked tbody td[data-label="Nome"],
    #viewTable .table-stacked tbody td.col-pendencia,
    #manutencaoTable .table-stacked tbody td[data-label="Equipamento"],
    #manutencaoHudTable .table-stacked tbody td[data-label="Equipamento"],
    #manutencaoTable .table-stacked tbody td[data-label="Destino"],
    #viewTable .table-stacked tbody td.actions,
    #manutencaoTable .table-stacked tbody td.actions,
    #manutencaoHudTable .table-stacked tbody td.actions {
        grid-column: 1 / -1 !important;
    }

    #viewTable .table-stacked tbody td.col-check {
        position: absolute !important;
        top: 15px !important;
        right: 15px !important;
        z-index: 2 !important;
        width: 28px !important;
        min-height: 28px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    #viewTable .table-stacked tbody td.col-check::before,
    #viewTable .table-stacked tbody td.actions::before,
    #manutencaoTable .table-stacked tbody td.actions::before,
    #manutencaoHudTable .table-stacked tbody td.actions::before {
        display: none !important;
    }

    #viewTable .table-stacked tbody td.col-check input {
        width: 24px !important;
        height: 24px !important;
        margin: 0 !important;
        accent-color: var(--primary) !important;
    }

    #viewTable .table-stacked tbody td[data-label="Nome"] strong,
    #manutencaoTable .table-stacked tbody td[data-label="Equipamento"] strong,
    #manutencaoHudTable .table-stacked tbody td[data-label="Equipamento"] strong {
        display: block !important;
        color: var(--text) !important;
        font-size: 18px !important;
        font-weight: 850 !important;
        line-height: 1.16 !important;
        max-width: calc(100% - 38px) !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    #manutencaoTable .table-stacked tbody td[data-label="Equipamento"] strong,
    #manutencaoHudTable .table-stacked tbody td[data-label="Equipamento"] strong {
        max-width: 100% !important;
    }

    #manutencaoTable .table-stacked tbody td[data-label="Equipamento"] small,
    #manutencaoHudTable .table-stacked tbody td[data-label="Equipamento"] small {
        color: var(--muted) !important;
        font-size: 13px !important;
        line-height: 1.35 !important;
    }

    #viewTable .table-stacked tbody .badge,
    #viewTable .table-stacked tbody .status-badge,
    #manutencaoTable .table-stacked tbody .badge,
    #manutencaoTable .table-stacked tbody .status-badge,
    #manutencaoHudTable .table-stacked tbody .badge,
    #manutencaoHudTable .table-stacked tbody .status-badge {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        min-height: 28px !important;
        padding: 5px 10px !important;
        border-radius: 999px !important;
        border: 1px solid rgba(148, 163, 184, 0.32) !important;
        font-size: 11px !important;
        font-weight: 850 !important;
        letter-spacing: 0.03em !important;
        line-height: 1.1 !important;
        text-align: center !important;
        text-transform: uppercase !important;
        white-space: nowrap !important;
    }

    #viewTable .table-stacked tbody td.actions,
    #manutencaoTable .table-stacked tbody td.actions,
    #manutencaoHudTable .table-stacked tbody td.actions {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 9px !important;
        margin-top: 4px !important;
        padding-top: 12px !important;
        border-top: 1px solid var(--border-light) !important;
    }

    #viewTable .table-stacked tbody td.actions .btn,
    #manutencaoTable .table-stacked tbody td.actions .btn,
    #manutencaoHudTable .table-stacked tbody td.actions .btn {
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
        min-height: 44px !important;
        height: auto !important;
        padding: 0 10px !important;
        border-radius: 12px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 7px !important;
        font-size: 13px !important;
        font-weight: 850 !important;
        line-height: 1 !important;
        box-shadow: none !important;
    }

    #viewTable .table-stacked tbody td.actions .btn-label,
    #viewTable .table-stacked tbody td.actions .btn-text,
    #manutencaoTable .table-stacked tbody td.actions .btn-label,
    #manutencaoTable .table-stacked tbody td.actions .btn-text,
    #manutencaoHudTable .table-stacked tbody td.actions .btn-label,
    #manutencaoHudTable .table-stacked tbody td.actions .btn-text {
        display: inline !important;
    }

    #viewTable .table-stacked tbody td.actions .btn svg,
    #manutencaoTable .table-stacked tbody td.actions .btn svg,
    #manutencaoHudTable .table-stacked tbody td.actions .btn svg {
        width: 15px !important;
        height: 15px !important;
        flex: 0 0 auto !important;
    }

    #viewTable .table-stacked tbody td.actions .btn-danger,
    #manutencaoTable .table-stacked tbody td.actions .btn-danger {
        grid-column: 1 / -1 !important;
    }

    #viewTable .table-stacked tbody td.actions .btn-info,
    #manutencaoTable .table-stacked tbody td.actions .btn-info,
    #manutencaoHudTable .table-stacked tbody td.actions .btn-info {
        color: #2563eb !important;
        border-color: rgba(37, 99, 235, 0.42) !important;
        background: rgba(37, 99, 235, 0.08) !important;
    }

    #viewTable .table-stacked tbody td.actions .btn-warning,
    #manutencaoTable .table-stacked tbody td.actions .btn-warning,
    #manutencaoHudTable .table-stacked tbody td.actions .btn-warning {
        color: #a16207 !important;
        border-color: rgba(217, 119, 6, 0.42) !important;
        background: rgba(245, 158, 11, 0.10) !important;
    }

    #viewTable .table-stacked tbody td.actions .btn-danger,
    #manutencaoTable .table-stacked tbody td.actions .btn-danger,
    #manutencaoHudTable .table-stacked tbody td.actions .btn-danger {
        color: #b91c1c !important;
        border-color: rgba(220, 38, 38, 0.42) !important;
        background: rgba(239, 68, 68, 0.10) !important;
    }

    #viewTable .table-stacked tbody td.actions .btn-maintenance-active {
        color: #b45309 !important;
        border-color: rgba(217, 119, 6, 0.58) !important;
        background: rgba(245, 158, 11, 0.16) !important;
    }

    #viewTable .table-stacked tbody td.actions .btn-maintenance-disabled {
        color: var(--muted) !important;
        border-color: var(--border-light) !important;
        background: var(--bg-alt) !important;
        opacity: 0.76 !important;
    }

    html.dark #viewTable .table-stacked tbody td.actions .btn-info,
    html.dark #manutencaoTable .table-stacked tbody td.actions .btn-info,
    html.dark #manutencaoHudTable .table-stacked tbody td.actions .btn-info {
        color: #bfdbfe !important;
        border-color: rgba(96, 165, 250, 0.52) !important;
        background: rgba(37, 99, 235, 0.20) !important;
    }

    html.dark #viewTable .table-stacked tbody td.actions .btn-warning,
    html.dark #manutencaoTable .table-stacked tbody td.actions .btn-warning,
    html.dark #manutencaoHudTable .table-stacked tbody td.actions .btn-warning {
        color: #fde68a !important;
        border-color: rgba(245, 158, 11, 0.56) !important;
        background: rgba(245, 158, 11, 0.18) !important;
    }

    html.dark #viewTable .table-stacked tbody td.actions .btn-danger,
    html.dark #manutencaoTable .table-stacked tbody td.actions .btn-danger,
    html.dark #manutencaoHudTable .table-stacked tbody td.actions .btn-danger {
        color: #fecaca !important;
        border-color: rgba(248, 113, 113, 0.56) !important;
        background: rgba(239, 68, 68, 0.18) !important;
    }

    html.dark #viewTable .table-stacked tbody td.actions .btn-maintenance-active {
        color: #fde68a !important;
        border-color: rgba(245, 158, 11, 0.62) !important;
        background: rgba(245, 158, 11, 0.24) !important;
    }

    #manutencaoHudTable .table-stacked tbody td[data-label="Equipamento"] {
        order: 1 !important;
    }

    #manutencaoHudTable .table-stacked tbody td[data-label="Site"] {
        order: 2 !important;
    }

    #manutencaoHudTable .table-stacked tbody td[data-label="Tipo"] {
        order: 3 !important;
    }

    #manutencaoHudTable .table-stacked tbody td[data-label="Prioridade"] {
        order: 4 !important;
    }

    #manutencaoHudTable .table-stacked tbody td[data-label="Status"] {
        order: 5 !important;
    }

    #manutencaoHudTable .table-stacked tbody td[data-label="Data"] {
        order: 6 !important;
    }

    #manutencaoHudTable .table-stacked tbody td.actions {
        order: 7 !important;
    }

    #manutencaoHudTable .table-stacked tbody td[data-label="Site"] strong {
        color: var(--text) !important;
        font-size: 16px !important;
        font-weight: 850 !important;
        line-height: 1.2 !important;
    }

    #manutencaoHudTable .table-stacked tbody td.actions .btn-ghost {
        color: var(--primary) !important;
        border-color: rgba(37, 99, 235, 0.24) !important;
        background: var(--surface) !important;
    }

    html.dark #manutencaoHudTable .table-stacked tbody td.actions .btn-ghost {
        color: #bfdbfe !important;
        border-color: rgba(96, 165, 250, 0.40) !important;
        background: rgba(15, 23, 42, 0.24) !important;
    }

    #sparePartsTable {
        overflow: visible !important;
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
    }

    #sparePartsTable .table-stacked tbody {
        display: block !important;
    }

    #sparePartsTable .table-stacked tbody tr {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 13px 16px !important;
        margin: 0 0 14px !important;
        padding: 16px !important;
        border-radius: 14px !important;
        border: 1px solid rgba(148, 163, 184, 0.22) !important;
        border-left: 5px solid var(--primary) !important;
        background: var(--surface) !important;
        box-shadow: 0 14px 32px rgba(15, 23, 42, 0.10) !important;
    }

    #sparePartsTable .table-stacked tbody tr.row-alert {
        border-left-color: var(--warning) !important;
    }

    #sparePartsTable .table-stacked tbody tr.row-site-match {
        border-left-color: var(--success) !important;
    }

    html.dark #sparePartsTable .table-stacked tbody tr {
        background: linear-gradient(145deg, rgba(30, 41, 69, 0.98), rgba(23, 34, 58, 0.98)) !important;
        border-color: rgba(148, 163, 184, 0.14) !important;
        box-shadow: 0 14px 30px rgba(0, 0, 0, 0.22) !important;
    }

    #sparePartsTable .table-stacked tbody td {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        justify-content: flex-start !important;
        gap: 6px !important;
        min-width: 0 !important;
        padding: 0 !important;
        border: 0 !important;
        color: var(--text) !important;
        font-size: 14px !important;
        line-height: 1.35 !important;
    }

    #sparePartsTable .table-stacked tbody td::before {
        content: attr(data-label) !important;
        display: block !important;
        margin: 0 !important;
        font-size: 10px !important;
        font-weight: 850 !important;
        letter-spacing: 0.08em !important;
        line-height: 1.1 !important;
        text-transform: uppercase !important;
        color: var(--muted) !important;
    }

    #sparePartsTable .table-stacked tbody td[data-label="Grupo"],
    #sparePartsTable .table-stacked tbody td[data-label="Situação"],
    #sparePartsTable .table-stacked tbody td.actions {
        grid-column: 1 / -1 !important;
    }

    #sparePartsTable .table-stacked tbody td[data-label="Grupo"] strong {
        display: block !important;
        color: var(--text) !important;
        font-size: 18px !important;
        font-weight: 850 !important;
        line-height: 1.16 !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    #sparePartsTable .table-stacked tbody td[data-label="Grupo"] small,
    #sparePartsTable .table-stacked tbody td[data-label="Livres"] small,
    #sparePartsTable .table-stacked tbody td[data-label="Cobertura"] small,
    #sparePartsTable .table-stacked tbody td[data-label="Situação"] small {
        color: var(--muted) !important;
        font-size: 13px !important;
        line-height: 1.35 !important;
    }

    #sparePartsTable .table-stacked tbody code {
        display: inline-flex !important;
        align-items: center !important;
        min-height: 28px !important;
        padding: 5px 8px !important;
        border-radius: 8px !important;
        border: 1px solid var(--border-light) !important;
        background: var(--bg-alt) !important;
        color: var(--text) !important;
        font-size: 13px !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    #sparePartsTable .table-stacked tbody .badge,
    #sparePartsTable .table-stacked tbody .status-badge {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        min-height: 28px !important;
        padding: 5px 10px !important;
        border-radius: 999px !important;
        border: 1px solid rgba(148, 163, 184, 0.32) !important;
        font-size: 11px !important;
        font-weight: 850 !important;
        letter-spacing: 0.03em !important;
        line-height: 1.1 !important;
        text-align: center !important;
        text-transform: uppercase !important;
        white-space: nowrap !important;
    }

    #sparePartsTable .spare-unit-list {
        margin-top: 8px !important;
        border-top: 1px solid var(--border-light) !important;
        padding-top: 8px !important;
    }

    #sparePartsTable .spare-unit-list summary {
        color: var(--primary) !important;
        font-size: 13px !important;
        font-weight: 800 !important;
    }

    #sparePartsTable .table-stacked tbody td.actions {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 9px !important;
        margin-top: 4px !important;
        padding-top: 12px !important;
        border-top: 1px solid var(--border-light) !important;
    }

    #sparePartsTable .table-stacked tbody td.actions::before {
        display: none !important;
    }

    #sparePartsTable .table-stacked tbody td.actions .btn {
        width: 100% !important;
        min-width: 0 !important;
        min-height: 44px !important;
        height: auto !important;
        padding: 0 10px !important;
        border-radius: 12px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 7px !important;
        font-size: 13px !important;
        font-weight: 850 !important;
        box-shadow: none !important;
    }

    #sparePartsTable .table-stacked tbody td.actions .btn-label {
        display: inline !important;
    }

    #sparePartsTable .table-stacked tbody td.actions .btn-danger {
        grid-column: 1 / -1 !important;
    }

    #sparePartsTable .table-stacked tbody td.actions .btn-info {
        color: #2563eb !important;
        border-color: rgba(37, 99, 235, 0.42) !important;
        background: rgba(37, 99, 235, 0.08) !important;
    }

    #sparePartsTable .table-stacked tbody td.actions .btn-warning {
        color: #a16207 !important;
        border-color: rgba(217, 119, 6, 0.42) !important;
        background: rgba(245, 158, 11, 0.10) !important;
    }

    #sparePartsTable .table-stacked tbody td.actions .btn-danger {
        color: #b91c1c !important;
        border-color: rgba(220, 38, 38, 0.42) !important;
        background: rgba(239, 68, 68, 0.10) !important;
    }

    html.dark #sparePartsTable .table-stacked tbody td.actions .btn-info {
        color: #bfdbfe !important;
        border-color: rgba(96, 165, 250, 0.52) !important;
        background: rgba(37, 99, 235, 0.20) !important;
    }

    html.dark #sparePartsTable .table-stacked tbody td.actions .btn-warning {
        color: #fde68a !important;
        border-color: rgba(245, 158, 11, 0.56) !important;
        background: rgba(245, 158, 11, 0.18) !important;
    }

    html.dark #sparePartsTable .table-stacked tbody td.actions .btn-danger {
        color: #fecaca !important;
        border-color: rgba(248, 113, 113, 0.56) !important;
        background: rgba(239, 68, 68, 0.18) !important;
    }

    .manutencao-flow-hint {
        display: block !important;
        padding: 14px 16px !important;
        line-height: 1.5 !important;
        text-align: left !important;
        word-break: normal !important;
        overflow-wrap: normal !important;
        white-space: normal !important;
    }

    .manutencao-flow-hint .info-alert-copy {
        display: block !important;
        min-width: 0 !important;
    }

    .manutencao-flow-hint strong {
        display: inline !important;
        white-space: nowrap !important;
    }

    body:not(.login-page) #viewToggle {
        display: inline-grid !important;
        grid-template-columns: repeat(2, 34px) !important;
        align-items: center !important;
        width: auto !important;
        min-height: 0 !important;
        padding: 3px !important;
        gap: 3px !important;
        border-radius: 13px !important;
    }

    #viewGrid .equipamento-card {
        border-radius: 14px !important;
        border: 1px solid rgba(148, 163, 184, 0.22) !important;
        border-left-width: 1px !important;
        box-shadow: 0 14px 32px rgba(15, 23, 42, 0.10) !important;
    }

    html.dark #viewGrid .equipamento-card {
        background: linear-gradient(145deg, rgba(30, 41, 69, 0.98), rgba(23, 34, 58, 0.98)) !important;
        border-color: rgba(148, 163, 184, 0.14) !important;
        box-shadow: 0 14px 30px rgba(0, 0, 0, 0.22) !important;
    }

    #dashboardEquipViewCards .equipamento-card {
        border-radius: 14px !important;
        border: 1px solid rgba(148, 163, 184, 0.22) !important;
        border-left-width: 1px !important;
        box-shadow: 0 14px 32px rgba(15, 23, 42, 0.10) !important;
    }

    html.dark #dashboardEquipViewCards .equipamento-card {
        background: linear-gradient(145deg, rgba(30, 41, 69, 0.98), rgba(23, 34, 58, 0.98)) !important;
        border-color: rgba(148, 163, 184, 0.14) !important;
        box-shadow: 0 14px 30px rgba(0, 0, 0, 0.22) !important;
    }

    #viewGrid .equipamento-card-actions {
        display: grid !important;
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
        gap: 8px !important;
        margin-top: 12px !important;
        padding-top: 12px !important;
        border-top: 1px solid var(--border-light) !important;
    }

    #dashboardEquipViewCards .equipamento-card-actions {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 8px !important;
        margin-top: 12px !important;
        padding-top: 12px !important;
        border-top: 1px solid var(--border-light) !important;
    }

    #dashboardEquipViewCards .equipamento-card-actions:has(.equip-foto-foot) {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto !important;
    }

    #dashboardEquipViewCards .equipamento-card-actions-main {
        display: contents !important;
    }

    #viewGrid .equipamento-card-actions .btn {
        width: 100% !important;
        min-width: 0 !important;
        min-height: 42px !important;
        height: 42px !important;
        padding: 0 !important;
        border-radius: 12px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 0 !important;
        font-size: 0 !important;
        font-weight: 850 !important;
        box-shadow: none !important;
    }

    #dashboardEquipViewCards .equipamento-card-actions .btn {
        width: 100% !important;
        min-width: 0 !important;
        min-height: 42px !important;
        height: 42px !important;
        padding: 0 10px !important;
        border-radius: 12px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 7px !important;
        font-size: 13px !important;
        font-weight: 850 !important;
        box-shadow: none !important;
    }

    #dashboardEquipViewCards .equip-foto-foot {
        align-self: stretch !important;
        justify-self: stretch !important;
        height: 42px !important;
        margin-left: 0 !important;
    }

    #viewGrid .equipamento-card-actions .btn svg {
        width: 17px !important;
        height: 17px !important;
        flex: 0 0 auto !important;
    }

    #dashboardEquipViewCards .equipamento-card-actions .btn svg {
        width: 17px !important;
        height: 17px !important;
        flex: 0 0 auto !important;
    }

    #viewGrid .equipamento-card-actions .equip-action-label {
        position: absolute !important;
        width: 1px !important;
        height: 1px !important;
        padding: 0 !important;
        margin: -1px !important;
        overflow: hidden !important;
        clip: rect(0, 0, 0, 0) !important;
        white-space: nowrap !important;
        border: 0 !important;
    }

    #viewGrid .equipamento-card-actions .btn-info {
        color: #2563eb !important;
        border-color: rgba(37, 99, 235, 0.42) !important;
        background: rgba(37, 99, 235, 0.08) !important;
    }

    #viewGrid .equipamento-card-actions .btn-warning {
        color: #a16207 !important;
        border-color: rgba(217, 119, 6, 0.42) !important;
        background: rgba(245, 158, 11, 0.10) !important;
    }

    #dashboardEquipViewCards .equipamento-card-actions .btn-info {
        color: #2563eb !important;
        border-color: rgba(37, 99, 235, 0.42) !important;
        background: rgba(37, 99, 235, 0.08) !important;
    }

    #dashboardEquipViewCards .equipamento-card-actions .btn-warning {
        color: #a16207 !important;
        border-color: rgba(217, 119, 6, 0.42) !important;
        background: rgba(245, 158, 11, 0.10) !important;
    }

    #viewGrid .equipamento-card-actions .btn-danger {
        color: #b91c1c !important;
        border-color: rgba(220, 38, 38, 0.42) !important;
        background: rgba(239, 68, 68, 0.10) !important;
    }

    #viewGrid .equipamento-card-actions .btn-maintenance-active {
        color: #b45309 !important;
        border-color: rgba(217, 119, 6, 0.58) !important;
        background: rgba(245, 158, 11, 0.16) !important;
    }

    #viewGrid .equipamento-card-actions .btn-maintenance-disabled {
        color: var(--muted) !important;
        border-color: var(--border-light) !important;
        background: var(--bg-alt) !important;
        opacity: 0.76 !important;
    }

    html.dark #viewGrid .equipamento-card-actions .btn-info {
        color: #bfdbfe !important;
        border-color: rgba(96, 165, 250, 0.52) !important;
        background: rgba(37, 99, 235, 0.20) !important;
    }

    html.dark #viewGrid .equipamento-card-actions .btn-warning {
        color: #fde68a !important;
        border-color: rgba(245, 158, 11, 0.56) !important;
        background: rgba(245, 158, 11, 0.18) !important;
    }

    html.dark #dashboardEquipViewCards .equipamento-card-actions .btn-info {
        color: #bfdbfe !important;
        border-color: rgba(96, 165, 250, 0.52) !important;
        background: rgba(37, 99, 235, 0.20) !important;
    }

    html.dark #dashboardEquipViewCards .equipamento-card-actions .btn-warning {
        color: #fde68a !important;
        border-color: rgba(245, 158, 11, 0.56) !important;
        background: rgba(245, 158, 11, 0.18) !important;
    }

    html.dark #viewGrid .equipamento-card-actions .btn-danger {
        color: #fecaca !important;
        border-color: rgba(248, 113, 113, 0.56) !important;
        background: rgba(239, 68, 68, 0.18) !important;
    }

    html.dark #viewGrid .equipamento-card-actions .btn-maintenance-active {
        color: #fde68a !important;
        border-color: rgba(245, 158, 11, 0.62) !important;
        background: rgba(245, 158, 11, 0.24) !important;
    }

    #viewTable .table-stacked tbody td.actions,
    #dashboardEquipViewTable .table-stacked tbody td.actions {
        display: grid !important;
        grid-template-columns: repeat(auto-fit, minmax(42px, 1fr)) !important;
        gap: 8px !important;
    }

    #viewTable .table-stacked tbody td.actions .btn,
    #dashboardEquipViewTable .table-stacked tbody td.actions .btn {
        width: 100% !important;
        min-width: 0 !important;
        min-height: 42px !important;
        height: 42px !important;
        padding: 0 !important;
        border-radius: 12px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 0 !important;
        font-size: 0 !important;
        line-height: 1 !important;
    }

    #viewTable .table-stacked tbody td.actions .btn-danger,
    #dashboardEquipViewTable .table-stacked tbody td.actions .btn-danger {
        grid-column: auto !important;
    }

    #viewTable .table-stacked tbody td.actions .btn svg,
    #dashboardEquipViewTable .table-stacked tbody td.actions .btn svg {
        width: 17px !important;
        height: 17px !important;
        flex: 0 0 auto !important;
    }

    #viewTable .table-stacked tbody td.actions .btn-label,
    #viewTable .table-stacked tbody td.actions .btn-text,
    #dashboardEquipViewTable .table-stacked tbody td.actions .btn-label,
    #dashboardEquipViewTable .table-stacked tbody td.actions .btn-text {
        position: absolute !important;
        width: 1px !important;
        height: 1px !important;
        padding: 0 !important;
        margin: -1px !important;
        overflow: hidden !important;
        clip: rect(0, 0, 0, 0) !important;
        white-space: nowrap !important;
        border: 0 !important;
    }
}

/* Mobile UX pass: footer stays at the bottom as a compact strip. */
@media (max-width: 768px) {
    body:not(.login-page) {
        min-height: 100vh;
        min-height: 100dvh;
        display: flex;
        flex-direction: column;
    }

    body:not(.login-page) .main-content {
        flex: 1 0 auto;
        min-height: 0 !important;
        padding-bottom: calc(12px + env(safe-area-inset-bottom)) !important;
    }

    body:not(.login-page) .container {
        padding-bottom: calc(12px + env(safe-area-inset-bottom));
    }

    body:not(.login-page) .footer {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        margin-top: auto !important;
        height: var(--topbar-height, 64px) !important;
        min-height: var(--topbar-height, 64px) !important;
        padding: 0 16px !important;
        box-sizing: border-box;
    }

    body:not(.login-page) .footer p {
        width: 100%;
        margin: 0;
        text-align: center;
        font-size: clamp(9px, 2.8vw, 11px);
        line-height: 1.2;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    body:not(.login-page) .mobile-nav {
        bottom: calc(24px + env(safe-area-inset-bottom)) !important;
    }
}

/* Equipamentos: manter seletor lista/cards e acao principal na mesma linha. */
@media (max-width: 768px) {
    .page-header .equipamentos-header-actions {
        width: 100% !important;
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 8px !important;
        min-width: 0 !important;
    }

    .equipamentos-header-actions #viewToggle {
        flex: 0 0 auto !important;
        width: auto !important;
        min-width: 0 !important;
    }

    .equipamentos-header-actions .view-btn {
        width: 34px !important;
        height: 34px !important;
        min-width: 34px !important;
        border-radius: 10px !important;
        padding: 0 !important;
        box-shadow: none;
    }

    .equipamentos-header-actions .view-btn.active {
        box-shadow: 0 7px 16px rgba(91, 55, 219, 0.28) !important;
    }

    .equipamentos-header-actions .view-btn svg {
        width: 15px !important;
        height: 15px !important;
    }

    .equipamentos-header-actions .equipamentos-new-btn {
        flex: 1 1 auto !important;
        width: auto !important;
        min-width: 0 !important;
        min-height: 42px !important;
        padding: 0 12px !important;
        justify-content: center !important;
        white-space: nowrap !important;
    }

    .equipamentos-header-actions .equipamentos-new-btn svg {
        flex: 0 0 auto;
    }
}

@media (max-width: 360px) {
    .equipamentos-header-actions #viewToggle {
        grid-template-columns: repeat(2, 32px) !important;
    }

    .equipamentos-header-actions .view-btn {
        width: 32px !important;
        height: 32px !important;
        min-width: 32px !important;
    }

    .equipamentos-header-actions .equipamentos-new-btn {
        padding: 0 10px !important;
        font-size: 12px !important;
    }
}

/* Mobile intro help: troca textos explicativos iniciais por um "?" expansivel. */
@media (max-width: 768px) {
    .mobile-intro-help {
        position: relative !important;
        display: inline-flex !important;
        align-items: flex-start !important;
        width: auto !important;
        min-width: 0 !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 0 12px !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        overflow: visible !important;
        z-index: 60 !important;
    }

    .page-header.nh-mobile-standard .mobile-intro-help.is-open,
    .page-header.nh-mobile-standard .page-subtitle.mobile-help-source.is-open {
        z-index: 1600 !important;
    }

    .mobile-help-trigger {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 28px !important;
        height: 28px !important;
        min-width: 28px !important;
        padding: 0 !important;
        border: 1px solid #b9cce8 !important;
        border-radius: 999px !important;
        background: linear-gradient(180deg, #eef5ff 0%, #dceafe 100%) !important;
        color: #1f51c6 !important;
        font-size: 13px !important;
        font-weight: 900 !important;
        line-height: 1 !important;
        box-shadow: 0 10px 22px rgba(15, 54, 109, 0.12) !important;
    }

    .mobile-intro-help::before {
        display: none !important;
        content: none !important;
    }

    .mobile-intro-help .info-alert-copy {
        display: none !important;
        position: absolute !important;
        left: 0 !important;
        top: calc(100% + 8px) !important;
        width: min(310px, calc(100vw - 64px)) !important;
        max-width: min(310px, calc(100vw - 64px)) !important;
        min-width: 0 !important;
        padding: 12px 14px !important;
        border: 1px solid #b9cce8 !important;
        border-radius: 14px !important;
        background: rgba(255, 255, 255, 0.98) !important;
        color: #183863 !important;
        font-size: 13px !important;
        font-weight: 650 !important;
        line-height: 1.45 !important;
        box-shadow: 0 18px 42px rgba(20, 56, 105, 0.18) !important;
        z-index: 1700 !important;
        white-space: normal !important;
        overflow-wrap: normal !important;
        word-break: normal !important;
    }

    .mobile-intro-help.is-open .info-alert-copy,
    .mobile-intro-help:focus-within .info-alert-copy {
        display: block !important;
    }

    .mobile-intro-help .info-alert-copy strong {
        color: #12345f !important;
        white-space: normal !important;
    }

    .page-header .page-subtitle.mobile-help-source {
        position: relative !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 28px !important;
        height: 28px !important;
        min-width: 28px !important;
        margin: 2px 0 0 !important;
        padding: 0 !important;
        border: 1px solid #b9cce8 !important;
        border-radius: 999px !important;
        background: linear-gradient(180deg, #eef5ff 0%, #dceafe 100%) !important;
        color: transparent !important;
        font-size: 0 !important;
        line-height: 1 !important;
        overflow: visible !important;
        cursor: pointer;
        z-index: 60 !important;
    }

    .page-header .page-subtitle.mobile-help-source::before {
        content: "?";
        color: #1f51c6;
        font-size: 13px;
        font-weight: 900;
        line-height: 1;
    }

    .page-header .page-subtitle.mobile-help-source::after {
        content: attr(data-mobile-help);
        display: none;
        position: absolute;
        left: 0;
        top: calc(100% + 8px);
        width: min(310px, calc(100vw - 64px));
        max-width: min(310px, calc(100vw - 64px));
        padding: 12px 14px;
        border: 1px solid #b9cce8;
        border-radius: 14px;
        background: rgba(255, 255, 255, 0.98);
        color: #183863;
        font-size: 13px;
        font-weight: 650;
        line-height: 1.45;
        box-shadow: 0 18px 42px rgba(20, 56, 105, 0.18);
        z-index: 1700 !important;
        white-space: normal;
    }

    html.dark .mobile-help-trigger,
    html.dark .page-header .page-subtitle.mobile-help-source {
        border-color: rgba(122, 148, 190, 0.38) !important;
        background: linear-gradient(180deg, rgba(32, 48, 78, 0.96), rgba(24, 38, 64, 0.96)) !important;
        color: #dce8fb !important;
        box-shadow: 0 10px 22px rgba(2, 6, 23, 0.24) !important;
    }

    html.dark .page-header .page-subtitle.mobile-help-source {
        color: transparent !important;
    }

    html.dark .page-header .page-subtitle.mobile-help-source::before {
        color: #dce8fb;
    }

    html.dark .mobile-intro-help .info-alert-copy,
    html.dark .page-header .page-subtitle.mobile-help-source::after {
        border-color: rgba(96, 165, 250, 0.34) !important;
        background: rgba(15, 27, 48, 0.98) !important;
        color: #e5efff !important;
        box-shadow: 0 18px 42px rgba(0, 0, 0, 0.34) !important;
    }

    html.dark .mobile-intro-help .info-alert-copy strong {
        color: #ffffff !important;
    }

    .page-header .page-subtitle.mobile-help-source.is-open::after,
    .page-header .page-subtitle.mobile-help-source:focus::after {
        display: block;
    }
}

/* V6 heroes keep their supporting copy visible instead of the legacy mobile help dot. */
@media (max-width: 768px) {
    body:not(.login-page) .nh-hero .mobile-help-trigger,
    body:not(.login-page) .nh-hero > .nh-mobile-header-help,
    body:not(.login-page) .nh-hero .mobile-intro-help {
        display: none !important;
    }

    body:not(.login-page) .nh-hero .page-subtitle.mobile-help-source {
        position: static !important;
        display: block !important;
        width: auto !important;
        height: auto !important;
        min-width: 0 !important;
        max-width: none !important;
        margin: 4px 0 0 !important;
        padding: 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        color: #4b6386 !important;
        font-size: 13px !important;
        font-weight: 650 !important;
        line-height: 1.4 !important;
        text-align: left !important;
        overflow: visible !important;
        cursor: default !important;
    }

    body:not(.login-page) .nh-hero .page-subtitle.mobile-help-source::before,
    body:not(.login-page) .nh-hero .page-subtitle.mobile-help-source::after {
        content: none !important;
        display: none !important;
    }

html.dark body:not(.login-page) .nh-hero .page-subtitle.mobile-help-source {
        color: #c4d4eb !important;
    }
}

/* Cadastro v6: mobile keeps the same hero action controls as desktop. */
@media (max-width: 768px) {
    body:not(.login-page) .page-header.nh-mobile-standard.cadastro-page-header .cadastro-header-actions {
        display: grid !important;
        grid-template-columns: 1fr !important;
        align-items: stretch !important;
        justify-content: stretch !important;
        width: 100% !important;
        max-width: 100% !important;
        gap: 10px !important;
        margin: 0 !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard.cadastro-page-header .cadastro-context-chips {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        width: 100% !important;
        max-width: none !important;
        gap: 8px !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard.cadastro-page-header .cadastro-back-btn {
        height: 38px !important;
        min-height: 38px !important;
        max-height: 38px !important;
        border-radius: 12px !important;
        border: 1px solid #bed2ef !important;
        background: rgba(239, 246, 255, 0.94) !important;
        color: #24466f !important;
        font-size: 12px !important;
        font-weight: 850 !important;
        line-height: 1 !important;
        letter-spacing: 0 !important;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard.cadastro-page-header .cadastro-context-chips span {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        min-width: 0 !important;
        height: 28px !important;
        min-height: 28px !important;
        max-height: 28px !important;
        border-radius: 999px !important;
        padding: 0 8px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard.cadastro-page-header .cadastro-back-btn {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        width: 100% !important;
        min-width: 0 !important;
        padding: 0 16px !important;
        margin: 0 !important;
        white-space: nowrap !important;
    }

    html.dark body:not(.login-page) .page-header.nh-mobile-standard.cadastro-page-header .cadastro-back-btn {
        border-color: rgba(125, 159, 210, 0.46) !important;
        background: rgba(20, 38, 68, 0.76) !important;
        color: #dce8fb !important;
    }
}

/* Analytics mobile v6: compact overview without duplicated insight cards. */
@media (max-width: 768px) {
    body:not(.login-page) .dash-insight-strip {
        display: none !important;
    }

    body:not(.login-page) .dash-hero-actions.dash-hero-actions-desktop {
        display: none !important;
    }

    body:not(.login-page) .dash-tab-content .kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 10px !important;
        margin-bottom: 18px !important;
    }

    body:not(.login-page) .dash-tab-content .kpi-card {
        min-height: 96px !important;
        align-items: flex-start !important;
        gap: 8px !important;
        padding: 12px 10px !important;
        border-radius: 14px !important;
    }

    body:not(.login-page) .dash-tab-content .kpi-card::before {
        width: 3px !important;
        border-radius: 3px 0 0 3px !important;
    }

    body:not(.login-page) .dash-tab-content .kpi-icon {
        width: 34px !important;
        height: 34px !important;
        flex: 0 0 34px !important;
        border-radius: 11px !important;
    }

    body:not(.login-page) .dash-tab-content .kpi-icon svg {
        width: 18px !important;
        height: 18px !important;
    }

    body:not(.login-page) .dash-tab-content .kpi-data {
        min-width: 0 !important;
        display: grid !important;
        gap: 2px !important;
    }

    body:not(.login-page) .dash-tab-content .kpi-value {
        font-size: 22px !important;
        line-height: 1 !important;
    }

    body:not(.login-page) .dash-tab-content .kpi-label {
        display: block !important;
        min-width: 0 !important;
        font-size: 11px !important;
        line-height: 1.15 !important;
        white-space: normal !important;
        overflow-wrap: anywhere !important;
    }

    body:not(.login-page) .dash-tab-content .kpi-pct,
    body:not(.login-page) .dash-tab-content .kpi-sub {
        font-size: 10px !important;
        line-height: 1.15 !important;
    }
}

/* Equipamentos mobile v6: lista/cards + acao primaria em uma unica barra compacta. */
@media (max-width: 960px) {
    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero > .equipamentos-header-actions,
    body:not(.login-page) .nh-hero .equipamentos-header-actions,
    body:not(.login-page) .page-header .equipamentos-header-actions {
        display: grid !important;
        grid-template-columns: auto minmax(0, 1fr) !important;
        align-items: center !important;
        justify-content: stretch !important;
        gap: 8px !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        margin: 0 !important;
    }

    body:not(.login-page) .equipamentos-header-actions #viewToggle,
    body:not(.login-page) .equipamentos-header-actions .view-toggle {
        width: auto !important;
        min-width: 0 !important;
        display: inline-grid !important;
        grid-template-columns: repeat(2, 36px) !important;
        gap: 4px !important;
        padding: 3px !important;
        border-radius: 14px !important;
        justify-self: start !important;
    }

    body:not(.login-page) .equipamentos-header-actions .view-btn {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
        min-height: 36px !important;
        padding: 0 !important;
        border-radius: 11px !important;
    }

    body:not(.login-page) .equipamentos-header-actions .view-btn svg {
        width: 15px !important;
        height: 15px !important;
    }

    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero > .equipamentos-header-actions .equipamentos-new-btn,
    body:not(.login-page) .equipamentos-header-actions .equipamentos-new-btn {
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        min-height: 42px !important;
        height: 42px !important;
        padding: 0 12px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    body:not(.login-page) .equipamentos-header-actions .equipamentos-new-btn svg {
        width: 15px !important;
        height: 15px !important;
        flex: 0 0 15px !important;
    }
}

@media (max-width: 360px) {
    body:not(.login-page) .equipamentos-header-actions #viewToggle,
    body:not(.login-page) .equipamentos-header-actions .view-toggle {
        grid-template-columns: repeat(2, 32px) !important;
    }

    body:not(.login-page) .equipamentos-header-actions .view-btn {
        width: 32px !important;
        height: 32px !important;
        min-width: 32px !important;
        min-height: 32px !important;
    }

    body:not(.login-page) .equipamentos-header-actions .equipamentos-new-btn {
        height: 40px !important;
        min-height: 40px !important;
        padding-inline: 10px !important;
        font-size: 12px !important;
    }
}

/* Manutencao mobile v6: remove ajuda textual repetida abaixo do hero. */
@media (max-width: 768px) {
    body:not(.login-page) .page-header.nh-mobile-standard.nh-hero .manutencao-flow-hint.mobile-intro-help.nh-mobile-header-help,
    body:not(.login-page) .manutencao-flow-hint,
    body:not(.login-page) .manutencao-flow-hint.mobile-intro-help,
    body:not(.login-page) .manutencao-flow-hint.nh-desktop-help {
        display: none !important;
    }
}

/* Spare mobile v6: KPIs em 3 + 2 para aproveitar melhor a largura. */
@media (max-width: 768px) {
    body:not(.login-page) .nh-page > .spare-kpi-grid,
    body:not(.login-page) .spare-kpi-grid {
        display: grid !important;
        grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
        gap: 8px !important;
        margin-bottom: 14px !important;
    }

    body:not(.login-page) .spare-kpi-grid .stat-card {
        grid-column: span 2 !important;
        min-width: 0 !important;
        min-height: 76px !important;
        padding: 10px 8px !important;
        gap: 8px !important;
        align-items: center !important;
    }

    body:not(.login-page) .spare-kpi-grid .stat-card:nth-child(n+4) {
        grid-column: span 3 !important;
    }

    body:not(.login-page) .spare-kpi-grid .stat-icon {
        width: 34px !important;
        height: 34px !important;
        min-width: 34px !important;
        border-radius: 11px !important;
    }

    body:not(.login-page) .spare-kpi-grid .stat-icon svg {
        width: 18px !important;
        height: 18px !important;
    }

    body:not(.login-page) .spare-kpi-grid .stat-info {
        min-width: 0 !important;
    }

    body:not(.login-page) .spare-kpi-grid .stat-info h3 {
        font-size: 18px !important;
        line-height: 1 !important;
        margin: 0 0 3px !important;
    }

    body:not(.login-page) .spare-kpi-grid .stat-info p {
        font-size: 10px !important;
        line-height: 1.15 !important;
        margin: 0 !important;
        white-space: normal !important;
        overflow-wrap: anywhere !important;
    }
}

/* ============================================
   MOBILE LOGIN 2026: marketing visual refresh
   ============================================ */
@media (max-width: 900px) {
    html {
        scroll-padding-top: 78px;
    }

    body.login-page,
    .login-page {
        min-height: 100svh !important;
        overflow-x: hidden !important;
        background:
            radial-gradient(circle at 18% 7%, rgba(56, 189, 248, 0.22), transparent 26%),
            radial-gradient(circle at 92% 18%, rgba(109, 61, 245, 0.28), transparent 34%),
            linear-gradient(180deg, #06162f 0%, #071c3c 48%, #061225 100%) !important;
        color: #eef7ff !important;
    }

    body.login-page::before {
        content: '' !important;
        position: fixed !important;
        inset: 0 !important;
        display: block !important;
        opacity: 0.42 !important;
        pointer-events: none !important;
        z-index: 0 !important;
        background:
            linear-gradient(90deg, rgba(118, 163, 255, 0.08) 1px, transparent 1px),
            linear-gradient(180deg, rgba(118, 163, 255, 0.07) 1px, transparent 1px) !important;
        background-size: 34px 34px !important;
        mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.94), rgba(0, 0, 0, 0.42) 58%, transparent) !important;
    }

    body.login-page::after {
        content: '' !important;
        position: fixed !important;
        inset: 0 !important;
        display: block !important;
        opacity: 0.58 !important;
        pointer-events: none !important;
        z-index: 0 !important;
        background:
            linear-gradient(180deg, rgba(3, 12, 31, 0.08), rgba(3, 12, 31, 0.64)),
            url('../img/login-hero-ai.webp') center top / cover no-repeat !important;
        filter: saturate(1.1) contrast(1.04) !important;
    }

    body.login-page .login-top-strip {
        display: none !important;
    }

    body.login-page .login-bg-grid {
        display: block !important;
        opacity: 0.34 !important;
        z-index: 0 !important;
    }

    body.login-page .login-particles {
        display: block !important;
        opacity: 0.8 !important;
        z-index: 0 !important;
    }

    body.login-page .login-nav,
    body.login-page.scrolled .login-nav {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 42 !important;
        background: rgba(4, 22, 51, 0.92) !important;
        border-bottom: 1px solid rgba(125, 184, 255, 0.2) !important;
        box-shadow: 0 16px 34px rgba(2, 8, 24, 0.22) !important;
        backdrop-filter: blur(18px) !important;
        -webkit-backdrop-filter: blur(18px) !important;
    }

    body.login-page .login-nav-inner {
        max-width: 480px !important;
        min-height: 68px !important;
        padding: 10px 14px !important;
        gap: 10px !important;
    }

    body.login-page .login-nav-brand strong {
        color: #f8fbff !important;
        font-size: 25px !important;
        letter-spacing: -0.035em !important;
    }

    body.login-page .login-nav-brand .brand-icon {
        width: 42px !important;
        height: 42px !important;
        border-radius: 13px !important;
        box-shadow: 0 12px 26px rgba(77, 44, 195, 0.35), 0 0 0 4px rgba(95, 121, 255, 0.14) !important;
    }

    body.login-page .login-nav-links,
    body.login-page .login-nav-actions .login-nav-btn-ghost {
        display: none !important;
    }

    body.login-page .login-nav-btn-primary,
    body.login-page .login-nav-btn-primary.is-mobile-hidden {
        min-width: 112px !important;
        max-width: none !important;
        width: auto !important;
        min-height: 40px !important;
        padding: 9px 13px !important;
        color: #ffffff !important;
        border-width: 1px !important;
        border-color: rgba(142, 190, 255, 0.48) !important;
        background: linear-gradient(135deg, #236edb 0%, #4f46e5 55%, #6d3df5 100%) !important;
        box-shadow: 0 10px 24px rgba(51, 78, 201, 0.36), 0 0 0 4px rgba(109, 61, 245, 0.12) !important;
        visibility: visible !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        transform: none !important;
    }

    body.login-page .login-shell {
        display: grid !important;
        grid-template-columns: 1fr !important;
        align-content: start !important;
        max-width: 480px !important;
        width: 100% !important;
        min-height: auto !important;
        margin: 0 auto !important;
        padding: 88px 16px 22px !important;
        gap: 16px !important;
        background: transparent !important;
        position: relative !important;
        z-index: 2 !important;
    }

    body.login-page .login-shell::before,
    body.login-page .login-shell::after {
        content: '' !important;
        display: block !important;
        position: absolute !important;
        pointer-events: none !important;
        border-radius: 18px !important;
        border: 1px solid rgba(125, 211, 252, 0.24) !important;
        background: linear-gradient(145deg, rgba(56, 189, 248, 0.22), rgba(109, 61, 245, 0.12)) !important;
        box-shadow: 0 20px 44px rgba(8, 92, 168, 0.22) !important;
        opacity: 0.78 !important;
        z-index: -1 !important;
        filter: none !important;
    }

    body.login-page .login-shell::before {
        width: 70px !important;
        height: 70px !important;
        left: -28px !important;
        top: 136px !important;
        transform: rotate(8deg) !important;
    }

    body.login-page .login-shell::after {
        width: 58px !important;
        height: 58px !important;
        right: -14px !important;
        top: 560px !important;
        transform: rotate(-9deg) !important;
    }

    body.login-page .login-showcase {
        order: 1 !important;
        display: flex !important;
        max-width: 100% !important;
        gap: 12px !important;
        padding: 0 !important;
        color: #f8fbff !important;
    }

    body.login-page .login-showcase-tag {
        align-self: flex-start !important;
        display: inline-flex !important;
        white-space: normal !important;
        max-width: 100% !important;
        padding: 7px 11px !important;
        border-radius: 999px !important;
        border: 1px solid rgba(125, 211, 252, 0.26) !important;
        background: linear-gradient(135deg, rgba(11, 44, 92, 0.82), rgba(66, 54, 150, 0.62)) !important;
        color: #dff8ff !important;
        font-size: 11px !important;
        line-height: 1.15 !important;
        box-shadow: 0 12px 26px rgba(2, 10, 28, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
    }

    body.login-page .login-showcase h1 {
        max-width: 100% !important;
        margin: 0 !important;
        font-size: clamp(29px, 8.2vw, 34px) !important;
        line-height: 1.08 !important;
        letter-spacing: -0.045em !important;
        color: #ffffff !important;
        background: linear-gradient(135deg, #ffffff 0%, #e3f8ff 42%, #94efff 65%, #c4b5fd 100%) !important;
        -webkit-background-clip: text !important;
        -webkit-text-fill-color: transparent !important;
        background-clip: text !important;
        text-shadow: 0 22px 48px rgba(0, 0, 0, 0.3) !important;
        overflow-wrap: normal !important;
        text-wrap: balance !important;
    }

    body.login-page .login-showcase > p {
        max-width: 34rem !important;
        margin: 0 !important;
        font-size: 15.5px !important;
        line-height: 1.55 !important;
        color: rgba(224, 239, 255, 0.9) !important;
    }

    body.login-page .login-showcase-benefits {
        max-width: 100% !important;
        margin-top: 2px !important;
    }

    body.login-page .login-showcase-benefits .login-mobile-marketing {
        padding: 11px !important;
        border-radius: 17px !important;
        border: 1px solid rgba(148, 189, 255, 0.24) !important;
        background:
            linear-gradient(155deg, rgba(7, 24, 55, 0.78), rgba(16, 45, 91, 0.58)),
            rgba(255, 255, 255, 0.06) !important;
        box-shadow: 0 18px 42px rgba(2, 10, 28, 0.26), inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
        backdrop-filter: blur(16px) !important;
        -webkit-backdrop-filter: blur(16px) !important;
    }

    body.login-page .login-showcase-benefits .login-mobile-marketing-title {
        color: #f7fbff !important;
        font-size: 12px !important;
    }

    body.login-page .login-showcase-benefits .login-mobile-marketing-subtitle {
        color: rgba(210, 230, 255, 0.82) !important;
        font-size: 12.5px !important;
    }

    body.login-page .login-showcase-benefits .login-mobile-marketing-list {
        grid-template-columns: 1fr !important;
        gap: 7px !important;
    }

    body.login-page .login-showcase-benefits .login-mobile-marketing-list li {
        min-height: 42px !important;
        padding: 8px !important;
        grid-template-columns: 18px minmax(0, 1fr) !important;
        gap: 7px !important;
        border-color: rgba(148, 189, 255, 0.2) !important;
        background: rgba(8, 30, 68, 0.62) !important;
        color: rgba(239, 247, 255, 0.94) !important;
        font-size: 12px !important;
        line-height: 1.25 !important;
    }

    body.login-page .login-showcase-benefits .login-mobile-marketing-list li:nth-child(n+4) {
        display: none !important;
    }

    body.login-page .login-showcase-benefits .login-mobile-marketing-bullet {
        width: 15px !important;
        height: 15px !important;
        background: linear-gradient(135deg, #22c55e 0%, #38bdf8 52%, #6d4bff 100%) !important;
        box-shadow: 0 0 0 4px rgba(56, 189, 248, 0.09), 0 8px 18px rgba(32, 118, 196, 0.26) !important;
    }

    body.login-page .login-card {
        order: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 18px !important;
        gap: 11px !important;
        border-radius: 20px !important;
        border: 1px solid rgba(190, 209, 239, 0.92) !important;
        background:
            radial-gradient(circle at 90% 0%, rgba(56, 189, 248, 0.18), transparent 30%),
            linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(238, 246, 255, 0.97)) !important;
        box-shadow: 0 28px 64px rgba(2, 10, 28, 0.34), 0 0 0 1px rgba(255, 255, 255, 0.6) inset !important;
        overflow: hidden !important;
    }

    body.login-page .login-card .login-brand {
        display: flex !important;
        margin-bottom: 0 !important;
        gap: 11px !important;
    }

    body.login-page .login-card .login-brand .brand-icon {
        width: 48px !important;
        height: 48px !important;
        border-radius: 14px !important;
        box-shadow: 0 14px 28px rgba(60, 45, 150, 0.26), 0 0 0 5px rgba(79, 70, 229, 0.08) !important;
    }

    body.login-page .login-brand h2 {
        color: #0c2240 !important;
        font-size: 28px !important;
        letter-spacing: -0.035em !important;
    }

    body.login-page .login-brand p {
        color: #52647d !important;
        font-size: 13px !important;
    }

    body.login-page .login-title-desktop {
        display: inline !important;
    }

    body.login-page .login-title-mobile {
        display: none !important;
    }

    body.login-page .login-card h3 {
        color: #0c2240 !important;
        font-size: clamp(28px, 8vw, 34px) !important;
        line-height: 1.04 !important;
        letter-spacing: -0.04em !important;
        margin: 0 !important;
    }

    body.login-page .login-card-subtitle {
        display: block !important;
        margin: 0 !important;
        color: #52647d !important;
        font-size: 14px !important;
        line-height: 1.45 !important;
    }

    body.login-page .login-card .form-group label {
        color: #304662 !important;
        font-size: 12.5px !important;
    }

    body.login-page .login-card .form-control {
        min-height: 50px !important;
        border-radius: 12px !important;
        border-color: #bfd0ea !important;
        background: #fbfdff !important;
        color: #122642 !important;
        font-size: 16px !important;
    }

    body.login-page .login-actions .btn {
        min-height: 52px !important;
        border-radius: 12px !important;
        font-size: 17px !important;
        background: linear-gradient(135deg, #1f6ed4 0%, #4f46e5 55%, #6d3df5 100%) !important;
        border-color: rgba(49, 112, 214, 0.78) !important;
        box-shadow: 0 14px 30px rgba(49, 89, 198, 0.28) !important;
    }

    body.login-page .info-login {
        border-radius: 13px !important;
        background: linear-gradient(180deg, rgba(239, 246, 255, 0.98), rgba(230, 239, 253, 0.98)) !important;
        border-color: rgba(183, 203, 235, 0.92) !important;
        color: #52647d !important;
    }

    body.login-page .login-mobile-command {
        order: 2 !important;
        display: grid !important;
        gap: 14px !important;
        padding: 17px !important;
        border-radius: 22px !important;
        border: 1px solid rgba(148, 189, 255, 0.22) !important;
        background:
            radial-gradient(circle at 80% 0%, rgba(56, 189, 248, 0.18), transparent 36%),
            linear-gradient(160deg, rgba(8, 28, 62, 0.86), rgba(11, 22, 54, 0.92)) !important;
        box-shadow: 0 26px 54px rgba(2, 8, 24, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
        overflow: hidden !important;
        position: relative !important;
    }

    body.login-page .login-mobile-command::before {
        content: '' !important;
        position: absolute !important;
        right: -34px !important;
        top: 18px !important;
        width: 76px !important;
        height: 76px !important;
        border-radius: 18px !important;
        border: 1px solid rgba(125, 211, 252, 0.22) !important;
        background: linear-gradient(145deg, rgba(56, 189, 248, 0.14), rgba(109, 61, 245, 0.12)) !important;
        transform: rotate(8deg) !important;
    }

    body.login-page .login-mobile-command-copy {
        position: relative !important;
        z-index: 1 !important;
        display: grid !important;
        gap: 8px !important;
    }

    body.login-page .login-mobile-command h2 {
        margin: 0 !important;
        color: #ffffff !important;
        font-size: clamp(25px, 7.8vw, 34px) !important;
        line-height: 1.05 !important;
        letter-spacing: -0.04em !important;
    }

    body.login-page .login-mobile-command p {
        margin: 0 !important;
        color: rgba(213, 231, 255, 0.82) !important;
        font-size: 14px !important;
        line-height: 1.52 !important;
    }

    body.login-page .login-mobile-device-stage {
        order: -1 !important;
        position: relative !important;
        min-height: 250px !important;
        margin: -4px -8px 0 !important;
        perspective: 900px !important;
        z-index: 1 !important;
    }

    body.login-page .login-mobile-device-stage figure {
        margin: 0 !important;
        position: absolute !important;
    }

    body.login-page .login-mobile-device-stage img {
        display: block !important;
        width: 100% !important;
        height: auto !important;
        image-rendering: auto !important;
        transform: translateZ(0) !important;
        filter: saturate(1.08) contrast(1.04) drop-shadow(0 18px 30px rgba(0, 0, 0, 0.34)) !important;
    }

    body.login-page .login-mobile-device-screen {
        left: 4% !important;
        bottom: 24px !important;
        width: 88% !important;
        border-radius: 16px !important;
        overflow: hidden !important;
        border: 1px solid rgba(148, 189, 255, 0.28) !important;
        transform: rotateX(8deg) rotateZ(-5deg) translateY(12px) !important;
        transform-origin: center bottom !important;
        box-shadow: 0 28px 54px rgba(0, 0, 0, 0.3) !important;
    }

    body.login-page .login-mobile-device-phone {
        z-index: 3 !important;
        transform-origin: center bottom !important;
    }

    body.login-page .login-mobile-device-phone-main {
        width: 41% !important;
        right: 8% !important;
        top: -6px !important;
        transform: rotateZ(4deg) !important;
    }

    body.login-page .login-mobile-device-phone-side {
        width: 34% !important;
        left: 2% !important;
        top: 58px !important;
        opacity: 0.94 !important;
        transform: rotateZ(-7deg) scale(0.94) !important;
        z-index: 2 !important;
    }

    body.login-page .login-mobile-command-rail {
        position: relative !important;
        z-index: 1 !important;
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 8px !important;
    }

    body.login-page .login-mobile-command-rail span {
        min-height: 30px !important;
        padding: 7px 10px !important;
        border-radius: 999px !important;
        border: 1px solid rgba(148, 189, 255, 0.24) !important;
        background: rgba(9, 32, 72, 0.72) !important;
        color: rgba(238, 247, 255, 0.92) !important;
        font-size: 12px !important;
        font-weight: 800 !important;
    }

    body.login-page .login-mobile-cue {
        display: inline-flex !important;
        left: 50% !important;
        right: auto !important;
        bottom: calc(10px + env(safe-area-inset-bottom)) !important;
        min-width: 158px !important;
        min-height: 40px !important;
        padding: 8px 13px !important;
        border-color: rgba(148, 189, 255, 0.38) !important;
        background:
            linear-gradient(145deg, rgba(10, 35, 76, 0.88), rgba(68, 45, 163, 0.86)),
            rgba(5, 16, 38, 0.82) !important;
        color: #eff7ff !important;
        box-shadow: 0 16px 34px rgba(5, 16, 38, 0.32), 0 0 0 5px rgba(56, 189, 248, 0.07) !important;
        transform: translate(-50%, 0) !important;
    }

    body.login-page .login-marquee,
    body.login-page .login-stats {
        display: none !important;
    }

    body.login-page .login-steps,
    body.login-page .login-workflow,
    body.login-page .login-interactive,
    body.login-page .login-help,
    body.login-page .login-faq {
        position: relative !important;
        z-index: 2 !important;
        border-top: 1px solid rgba(125, 184, 255, 0.15) !important;
        background:
            radial-gradient(circle at 18% 8%, rgba(56, 189, 248, 0.16), transparent 32%),
            radial-gradient(circle at 92% 16%, rgba(109, 61, 245, 0.14), transparent 34%),
            linear-gradient(180deg, #071b39 0%, #06162f 100%) !important;
    }

    body.login-page .login-workflow,
    body.login-page .login-faq {
        background:
            radial-gradient(circle at 82% 8%, rgba(109, 61, 245, 0.18), transparent 34%),
            linear-gradient(180deg, #06162f 0%, #091f42 100%) !important;
    }

    body.login-page .login-steps-inner,
    body.login-page .login-workflow-inner,
    body.login-page .login-interactive-inner,
    body.login-page .login-help-inner,
    body.login-page .login-faq-inner,
    body.login-page .login-contact-inner {
        max-width: 480px !important;
        padding: 42px 16px !important;
    }

    body.login-page .login-section-lead {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 18px !important;
        margin: 0 0 18px !important;
    }

    body.login-page .login-section-lead-copy,
    body.login-page .login-workflow-header,
    body.login-page .login-interactive-header,
    body.login-page .login-help-header,
    body.login-page .login-faq-header,
    body.login-page .login-contact-header {
        text-align: left !important;
        align-items: flex-start !important;
    }

    body.login-page .login-section-kicker {
        display: inline-flex !important;
        width: fit-content !important;
        min-height: 28px !important;
        margin: 0 0 10px !important;
        border-color: rgba(148, 189, 255, 0.28) !important;
        background: rgba(9, 32, 72, 0.74) !important;
        color: #c9f5ff !important;
        box-shadow: 0 12px 24px rgba(2, 10, 28, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
    }

    body.login-page .login-steps-inner h2,
    body.login-page .login-workflow-header h2,
    body.login-page .login-interactive-header h2,
    body.login-page .login-help-header h2,
    body.login-page .login-faq-header h2 {
        margin: 0 0 10px !important;
        color: #ffffff !important;
        font-size: clamp(30px, 9.5vw, 42px) !important;
        line-height: 1.05 !important;
        letter-spacing: -0.045em !important;
    }

    body.login-page .login-section-lead-copy > p,
    body.login-page .login-workflow-header p,
    body.login-page .login-interactive-header p,
    body.login-page .login-help-header p,
    body.login-page .login-faq-header p {
        max-width: 34rem !important;
        margin: 0 !important;
        color: rgba(213, 231, 255, 0.82) !important;
        font-size: 14.5px !important;
        line-height: 1.58 !important;
    }

    body.login-page .login-section-visual {
        width: calc(100% + 20px) !important;
        margin: 4px -10px 0 !important;
        border-radius: 18px !important;
        border: 1px solid rgba(148, 189, 255, 0.28) !important;
        background: rgba(6, 18, 43, 0.84) !important;
        box-shadow: 0 30px 58px rgba(0, 0, 0, 0.32), 0 0 0 1px rgba(255, 255, 255, 0.05) inset !important;
        transform: perspective(900px) rotateX(4deg) rotateZ(-2.2deg) !important;
    }

    body.login-page .login-section-visual img {
        filter: saturate(1.08) contrast(1.05) !important;
        object-fit: cover !important;
    }

    body.login-page .login-steps-grid,
    body.login-page .login-workflow-grid,
    body.login-page .login-help-grid,
    body.login-page .login-faq-grid,
    body.login-page .login-contact-grid {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }

    body.login-page .login-step-card,
    body.login-page .login-workflow-card,
    body.login-page .login-feature-card,
    body.login-page .login-help-item,
    body.login-page .login-faq-item,
    body.login-page .login-contact-card {
        border-radius: 18px !important;
        border-color: rgba(148, 189, 255, 0.22) !important;
        background:
            linear-gradient(158deg, rgba(10, 32, 70, 0.9), rgba(13, 26, 58, 0.9)),
            rgba(255, 255, 255, 0.05) !important;
        box-shadow: 0 18px 38px rgba(2, 8, 24, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.07) !important;
    }

    body.login-page .login-step-card h3,
    body.login-page .login-workflow-card h3,
    body.login-page .login-feature-title,
    body.login-page .login-help-item h3,
    body.login-page .login-faq-item h3,
    body.login-page .login-contact-card h3 {
        color: #ffffff !important;
        font-size: 17px !important;
    }

    body.login-page .login-step-card p,
    body.login-page .login-workflow-card p,
    body.login-page .login-feature-summary,
    body.login-page .login-help-item p,
    body.login-page .login-faq-item p,
    body.login-page .login-contact-card p {
        color: rgba(211, 228, 250, 0.8) !important;
        font-size: 13.5px !important;
        line-height: 1.5 !important;
    }

    body.login-page .login-step-icon,
    body.login-page .login-workflow-icon,
    body.login-page .login-feature-icon,
    body.login-page .login-help-icon,
    body.login-page .login-contact-icon {
        background: linear-gradient(145deg, rgba(56, 189, 248, 0.2), rgba(109, 61, 245, 0.24)) !important;
        border-color: rgba(148, 189, 255, 0.26) !important;
        color: #9eeaff !important;
        box-shadow: 0 12px 24px rgba(2, 10, 28, 0.22) !important;
    }

    body.login-page .login-feature-stage,
    body.login-page .login-module-grid {
        display: grid !important;
    }

    body.login-page .login-feature-stage {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
        padding: 16px !important;
        margin: 18px 0 !important;
        min-height: 0 !important;
        border-radius: 22px !important;
        border: 1px solid rgba(148, 189, 255, 0.22) !important;
        background:
            radial-gradient(circle at 78% 10%, rgba(56, 189, 248, 0.16), transparent 32%),
            linear-gradient(160deg, rgba(8, 28, 62, 0.9), rgba(12, 23, 55, 0.94)) !important;
        box-shadow: 0 24px 50px rgba(2, 8, 24, 0.3) !important;
        overflow: hidden !important;
    }

    body.login-page .login-feature-stage-copy h3 {
        color: #ffffff !important;
        font-size: clamp(24px, 7.6vw, 34px) !important;
        line-height: 1.08 !important;
        letter-spacing: -0.04em !important;
    }

    body.login-page .login-feature-stage-copy p {
        color: rgba(213, 231, 255, 0.82) !important;
        font-size: 14px !important;
    }

    body.login-page .login-feature-stage-actions {
        grid-template-columns: 1fr !important;
    }

    body.login-page .login-module-orbit {
        min-height: 340px !important;
        margin: 0 -4px !important;
        transform: none !important;
    }

    body.login-page .login-module-orbit .login-orbit-screen-main {
        width: 88% !important;
        left: 0 !important;
        top: 26px !important;
        transform: rotateZ(-4deg) !important;
    }

    body.login-page .login-module-orbit .login-orbit-screen-left {
        width: 68% !important;
        left: 2% !important;
        bottom: 26px !important;
        transform: rotateZ(5deg) !important;
    }

    body.login-page .login-orbit-phone {
        width: 38% !important;
        right: 1% !important;
        top: 18px !important;
        transform: rotateZ(5deg) !important;
    }

    body.login-page .login-module-chip {
        font-size: 11px !important;
        border-color: rgba(148, 189, 255, 0.28) !important;
        color: #163255 !important;
    }

    body.login-page .login-module-grid {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
        margin-top: 8px !important;
    }

    body.login-page .login-module-grid article {
        border-color: rgba(148, 189, 255, 0.22) !important;
        background: rgba(9, 32, 72, 0.72) !important;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.07) !important;
    }

    body.login-page .login-module-grid strong {
        color: #ffffff !important;
    }

    body.login-page .login-module-grid span {
        color: rgba(211, 228, 250, 0.8) !important;
    }

    body.login-page .login-filters {
        position: sticky !important;
        top: 76px !important;
        z-index: 12 !important;
        padding: 6px !important;
        border-radius: 16px !important;
        border: 1px solid rgba(148, 189, 255, 0.2) !important;
        background: rgba(7, 24, 55, 0.92) !important;
        backdrop-filter: blur(14px) !important;
        -webkit-backdrop-filter: blur(14px) !important;
    }

    body.login-page .login-filter-btn {
        color: rgba(224, 239, 255, 0.82) !important;
        border-color: rgba(148, 189, 255, 0.2) !important;
        background: rgba(12, 38, 82, 0.78) !important;
    }

    body.login-page .login-filter-btn.active {
        color: #ffffff !important;
        border-color: rgba(86, 143, 255, 0.62) !important;
        background: linear-gradient(135deg, rgba(35, 110, 219, 0.92), rgba(109, 61, 245, 0.86)) !important;
    }

    body.login-page .login-footer,
    body.login-page .login-contact {
        position: relative !important;
        z-index: 2 !important;
        background:
            radial-gradient(circle at 15% 20%, rgba(56, 189, 248, 0.14), transparent 34%),
            radial-gradient(circle at 80% 15%, rgba(135, 117, 255, 0.14), transparent 32%),
            linear-gradient(180deg, #092344 0%, #06162f 100%) !important;
    }
}

@media (max-width: 520px) {
    body.login-page .login-showcase-benefits .login-mobile-marketing-list {
        grid-template-columns: 1fr !important;
    }

    body.login-page .login-mobile-device-stage {
        min-height: 238px !important;
    }

    body.login-page .login-mobile-device-phone-main {
        width: 45% !important;
        right: 6% !important;
    }

    body.login-page .login-mobile-device-phone-side {
        width: 37% !important;
        left: 1% !important;
    }

    body.login-page .login-module-orbit {
        min-height: 310px !important;
    }
}

@media (max-width: 380px) {
    body.login-page .login-nav-brand strong {
        font-size: 22px !important;
    }

    body.login-page .login-nav-btn-primary {
        min-width: 104px !important;
        padding-inline: 11px !important;
        font-size: 11px !important;
    }

    body.login-page .login-shell {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    body.login-page .login-mobile-device-stage {
        min-height: 218px !important;
    }
}

@media (max-width: 900px) and (prefers-reduced-motion: no-preference) {
    body.login-page .login-showcase-tag {
        animation: nodehubMobileRise 520ms cubic-bezier(0.16, 1, 0.3, 1) 80ms both !important;
    }

    body.login-page .login-showcase h1 {
        animation: nodehubMobileTitleKick 720ms cubic-bezier(0.16, 1, 0.3, 1) 150ms both !important;
    }

    body.login-page .login-showcase > p,
    body.login-page .login-showcase-benefits .login-mobile-marketing {
        animation: nodehubMobileRise 620ms cubic-bezier(0.16, 1, 0.3, 1) 260ms both !important;
    }

    body.login-page .login-card {
        animation: nodehubMobileCardPop 760ms cubic-bezier(0.16, 1, 0.3, 1) 420ms both !important;
    }

    body.login-page .login-mobile-command {
        animation: nodehubMobileRise 760ms cubic-bezier(0.16, 1, 0.3, 1) 560ms both !important;
    }

    body.login-page .login-mobile-device-phone-main img {
        animation: nodehubMobilePhoneFloat 4.4s ease-in-out 1s infinite !important;
    }

    body.login-page .login-mobile-device-phone-side img {
        animation: nodehubMobilePhoneFloatAlt 5.2s ease-in-out 1.2s infinite !important;
    }

    body.login-page .login-mobile-device-screen img,
    body.login-page .login-section-visual img {
        animation: nodehubMobileScreenGlow 5.6s ease-in-out 1.1s infinite !important;
    }
}

@keyframes nodehubMobileRise {
    from {
        opacity: 0;
        transform: translate3d(0, 18px, 0) scale(0.985);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0) scale(1);
    }
}

@keyframes nodehubMobileTitleKick {
    0% {
        opacity: 0;
        transform: translate3d(0, 24px, 0) scale(0.98);
        filter: blur(2px);
    }
    72% {
        opacity: 1;
        transform: translate3d(0, -2px, 0) scale(1.01);
        filter: blur(0);
    }
    100% {
        opacity: 1;
        transform: translate3d(0, 0, 0) scale(1);
        filter: blur(0);
    }
}

@keyframes nodehubMobileCardPop {
    0% {
        opacity: 0;
        transform: translate3d(0, 22px, 0) scale(0.965);
    }
    68% {
        opacity: 1;
        transform: translate3d(0, -3px, 0) scale(1.004);
    }
    100% {
        opacity: 1;
        transform: translate3d(0, 0, 0) scale(1);
    }
}

@keyframes nodehubMobilePhoneFloat {
    0%, 100% { transform: translate3d(0, 0, 0) rotate(0deg); }
    50% { transform: translate3d(0, -10px, 0) rotate(1deg); }
}

@keyframes nodehubMobilePhoneFloatAlt {
    0%, 100% { transform: translate3d(0, 0, 0) rotate(0deg); }
    50% { transform: translate3d(0, -7px, 0) rotate(-1deg); }
}

@keyframes nodehubMobileScreenGlow {
    0%, 100% {
        filter: saturate(1.08) contrast(1.04) drop-shadow(0 18px 30px rgba(0, 0, 0, 0.34));
    }
    50% {
        filter: saturate(1.16) contrast(1.08) drop-shadow(0 22px 38px rgba(33, 150, 243, 0.28));
    }
}

/* Mobile login v2: simple, high-contrast, no text over screenshots. */
@media (max-width: 900px) {
    body.login-page,
    .login-page {
        background:
            radial-gradient(circle at 16% 0%, rgba(56, 189, 248, 0.2), transparent 28%),
            radial-gradient(circle at 88% 10%, rgba(109, 61, 245, 0.18), transparent 34%),
            linear-gradient(180deg, #06162f 0%, #071a36 52%, #061225 100%) !important;
    }

    body.login-page::after {
        display: none !important;
        content: none !important;
        background: none !important;
    }

    body.login-page::before {
        opacity: 0.2 !important;
        mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.88), transparent 70%) !important;
    }

    body.login-page .login-shell {
        padding-top: 82px !important;
        gap: 14px !important;
    }

    body.login-page .login-card {
        order: 0 !important;
    }

    body.login-page .login-showcase {
        order: 1 !important;
        padding: 2px 0 0 !important;
        gap: 9px !important;
    }

    body.login-page .login-showcase-tag {
        display: none !important;
    }

    body.login-page .login-showcase h1 {
        font-size: clamp(26px, 7.4vw, 32px) !important;
        line-height: 1.08 !important;
        letter-spacing: -0.04em !important;
        text-wrap: balance !important;
    }

    body.login-page .login-showcase > p {
        font-size: 14px !important;
        line-height: 1.5 !important;
        color: rgba(222, 238, 255, 0.88) !important;
    }

    body.login-page .login-showcase-benefits {
        display: none !important;
    }

    body.login-page .login-mobile-cue {
        display: none !important;
    }

    body.login-page .login-marquee,
    body.login-page .login-stats,
    body.login-page .login-interactive,
    body.login-page .login-help,
    body.login-page .login-faq,
    body.login-page .login-contact {
        display: none !important;
    }

    body.login-page .login-mobile-command {
        order: 2 !important;
        gap: 12px !important;
        padding: 14px !important;
        border-radius: 20px !important;
        background:
            radial-gradient(circle at 92% 0%, rgba(56, 189, 248, 0.13), transparent 38%),
            linear-gradient(180deg, rgba(9, 32, 72, 0.92), rgba(7, 23, 51, 0.96)) !important;
    }

    body.login-page .login-mobile-command::before {
        display: none !important;
    }

    body.login-page .login-mobile-command-copy {
        order: 0 !important;
        padding-bottom: 2px !important;
    }

    body.login-page .login-mobile-command h2 {
        font-size: clamp(22px, 6.6vw, 28px) !important;
        line-height: 1.08 !important;
        color: #ffffff !important;
    }

    body.login-page .login-mobile-command p {
        font-size: 13.5px !important;
        line-height: 1.48 !important;
        color: rgba(217, 233, 255, 0.84) !important;
    }

    body.login-page .login-mobile-device-stage {
        order: 1 !important;
        position: relative !important;
        display: block !important;
        min-height: clamp(160px, 47vw, 196px) !important;
        margin: 2px 0 4px !important;
        perspective: 900px !important;
        overflow: hidden !important;
        border-radius: 18px !important;
        border: 1px solid rgba(125, 184, 255, 0.22) !important;
        background:
            radial-gradient(circle at 82% 8%, rgba(56, 189, 248, 0.15), transparent 34%),
            linear-gradient(145deg, rgba(5, 19, 45, 0.56), rgba(8, 31, 69, 0.76)) !important;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), 0 18px 34px rgba(1, 8, 24, 0.26) !important;
    }

    body.login-page .login-mobile-device-stage figure {
        position: absolute !important;
        margin: 0 !important;
        transform-origin: center bottom !important;
    }

    body.login-page .login-mobile-device-stage .login-mobile-device-screen {
        top: 54px !important;
        right: auto !important;
        left: -5% !important;
        bottom: auto !important;
        width: 82% !important;
        border-radius: 15px !important;
        overflow: hidden !important;
        border: 1px solid rgba(148, 189, 255, 0.28) !important;
        opacity: 0.96 !important;
        z-index: 2 !important;
        transform: rotateX(7deg) rotateZ(-4deg) translateY(0) !important;
        box-shadow: 0 18px 34px rgba(0, 0, 0, 0.24) !important;
    }

    body.login-page .login-mobile-device-stage .login-mobile-device-phone-side {
        display: block !important;
        right: auto !important;
        bottom: auto !important;
        left: 6% !important;
        top: 18px !important;
        width: min(17%, 58px) !important;
        opacity: 0.78 !important;
        z-index: 3 !important;
        transform: rotateZ(-7deg) scale(0.98) !important;
    }

    body.login-page .login-mobile-device-stage .login-mobile-device-phone-main {
        left: auto !important;
        bottom: auto !important;
        right: 5% !important;
        top: 12px !important;
        width: min(23%, 82px) !important;
        z-index: 4 !important;
        transform: rotateZ(5deg) !important;
    }

    body.login-page .login-mobile-device-stage img {
        transform: none !important;
        width: 100% !important;
        height: auto !important;
        filter: saturate(1.08) contrast(1.05) drop-shadow(0 16px 26px rgba(0, 0, 0, 0.28)) !important;
    }

    body.login-page .login-mobile-command-rail {
        order: 2 !important;
        display: none !important;
        gap: 7px !important;
    }

    body.login-page .login-mobile-command-rail span {
        min-height: 28px !important;
        padding: 6px 9px !important;
        font-size: 11px !important;
        background: rgba(13, 45, 94, 0.72) !important;
        color: rgba(239, 247, 255, 0.96) !important;
    }

    body.login-page .login-steps,
    body.login-page .login-workflow {
        display: block !important;
        background:
            radial-gradient(circle at 85% 0%, rgba(109, 61, 245, 0.13), transparent 32%),
            linear-gradient(180deg, #071a36 0%, #06162f 100%) !important;
    }

    body.login-page .login-steps-inner,
    body.login-page .login-workflow-inner {
        padding: 34px 16px !important;
    }

    body.login-page .login-section-lead,
    body.login-page .login-section-lead-workflow {
        gap: 14px !important;
        margin-bottom: 14px !important;
    }

    body.login-page .login-section-kicker {
        min-height: 26px !important;
        margin-bottom: 9px !important;
        padding: 6px 9px !important;
        font-size: 9px !important;
        background: rgba(13, 45, 94, 0.82) !important;
        color: #d8f6ff !important;
    }

    body.login-page .login-steps-inner h2,
    body.login-page .login-workflow-header h2 {
        font-size: clamp(25px, 7.4vw, 32px) !important;
        line-height: 1.08 !important;
        color: #ffffff !important;
        letter-spacing: -0.04em !important;
    }

    body.login-page .login-section-lead-copy > p,
    body.login-page .login-workflow-header p {
        font-size: 13.5px !important;
        line-height: 1.5 !important;
        color: rgba(217, 233, 255, 0.84) !important;
    }

    body.login-page .login-section-visual {
        width: 100% !important;
        margin: 0 !important;
        border-radius: 16px !important;
        transform: none !important;
        border-color: rgba(148, 189, 255, 0.28) !important;
        box-shadow: 0 20px 38px rgba(0, 0, 0, 0.28) !important;
        background: rgba(7, 23, 51, 0.9) !important;
    }

    body.login-page .login-section-visual img {
        filter: saturate(1.04) contrast(1.04) !important;
    }

    body.login-page .login-steps-grid,
    body.login-page .login-workflow-grid {
        gap: 9px !important;
    }

    body.login-page .login-step-card,
    body.login-page .login-workflow-card {
        min-height: 0 !important;
        padding: 13px !important;
        border-radius: 16px !important;
        background: rgba(9, 32, 72, 0.86) !important;
        border-color: rgba(148, 189, 255, 0.22) !important;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06) !important;
    }

    body.login-page .login-step-card:nth-child(n+3),
    body.login-page .login-workflow-card:nth-child(n+3) {
        display: none !important;
    }

    body.login-page .login-step-icon,
    body.login-page .login-workflow-icon {
        width: 36px !important;
        height: 36px !important;
        border-radius: 12px !important;
        color: #9eeaff !important;
    }

    body.login-page .login-step-card h3,
    body.login-page .login-workflow-card h3 {
        color: #ffffff !important;
        font-size: 15.5px !important;
        line-height: 1.2 !important;
    }

    body.login-page .login-step-card p,
    body.login-page .login-workflow-card p {
        color: rgba(213, 231, 255, 0.82) !important;
        font-size: 12.5px !important;
        line-height: 1.45 !important;
    }

    body.login-page .login-footer {
        position: relative !important;
        z-index: 2 !important;
        background: #06162f !important;
        border-top: 1px solid rgba(148, 189, 255, 0.16) !important;
    }

    body.login-page .login-footer-brand span:last-child,
    body.login-page .login-footer-meta {
        color: rgba(213, 231, 255, 0.78) !important;
    }

    body.login-page .login-nav,
    body.login-page.scrolled .login-nav {
        transition:
            opacity 360ms ease,
            transform 520ms cubic-bezier(0.18, 0.84, 0.28, 1),
            filter 420ms ease,
            box-shadow 260ms ease,
            visibility 0ms linear 0ms !important;
        will-change: opacity, transform, filter !important;
    }

    body.login-page,
    body.login-page .login-shell,
    body.login-page .login-card {
        box-sizing: border-box !important;
        max-width: 100vw !important;
    }

    body.login-page {
        overflow-x: hidden !important;
    }

    body.login-page .login-shell {
        width: 100% !important;
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    body.login-page .login-card {
        width: min(100%, calc(100vw - 32px)) !important;
    }

    body.login-page .info-login span {
        overflow-wrap: anywhere !important;
    }

    body.login-page:not(.scrolled) .login-nav {
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
        transform: translate3d(0, -112%, 0) scale(0.985) !important;
        filter: blur(8px) !important;
        box-shadow: none !important;
        transition:
            opacity 300ms ease,
            transform 420ms cubic-bezier(0.22, 0.61, 0.36, 1),
            filter 340ms ease,
            visibility 0ms linear 420ms !important;
    }

    body.login-page.scrolled .login-nav {
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        transform: translate3d(0, 0, 0) scale(1) !important;
        filter: blur(0) !important;
        animation: loginMobileHeaderReveal 560ms cubic-bezier(0.18, 0.84, 0.28, 1) both !important;
    }

    body.login-page .login-nav-btn-primary svg {
        transform: rotate(180deg) !important;
    }

    body.login-page .login-shell {
        padding-top: 16px !important;
    }
}

/* Mobile login: light sections to match the desktop rhythm. */
@media (max-width: 900px) {
    body.login-page .login-nav,
    body.login-page.scrolled .login-nav {
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
        transform: translate3d(0, -26px, 0) scale(0.975) !important;
        filter: blur(10px) saturate(0.92) !important;
        transition:
            opacity 520ms ease,
            transform 680ms cubic-bezier(0.16, 1, 0.3, 1),
            filter 560ms ease,
            box-shadow 420ms ease,
            background-color 420ms ease,
            visibility 0ms linear 680ms !important;
        animation: none !important;
        will-change: opacity, transform, filter !important;
    }

    body.login-page.scrolled .login-nav {
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        transform: translate3d(0, 0, 0) scale(1) !important;
        filter: blur(0) saturate(1) !important;
        box-shadow: 0 14px 28px rgba(8, 28, 62, 0.14) !important;
        transition:
            opacity 560ms ease,
            transform 720ms cubic-bezier(0.16, 1, 0.3, 1),
            filter 580ms ease,
            box-shadow 420ms ease,
            background-color 420ms ease,
            visibility 0ms linear 0ms !important;
        animation: none !important;
    }

    body.login-page .login-steps,
    body.login-page .login-workflow {
        display: block !important;
        position: relative !important;
        z-index: 2 !important;
        border-top: 1px solid rgba(190, 211, 238, 0.78) !important;
        background:
            radial-gradient(circle at 14% 0%, rgba(56, 189, 248, 0.14), transparent 30%),
            radial-gradient(circle at 92% 16%, rgba(109, 61, 245, 0.1), transparent 34%),
            linear-gradient(180deg, #f3f8ff 0%, #eaf3ff 100%) !important;
        color: #0e2542 !important;
    }

    body.login-page .login-workflow {
        background:
            radial-gradient(circle at 82% 0%, rgba(56, 189, 248, 0.12), transparent 28%),
            linear-gradient(180deg, #eef6ff 0%, #f8fbff 100%) !important;
    }

    body.login-page .login-steps::before,
    body.login-page .login-workflow::before {
        content: '' !important;
        position: absolute !important;
        inset: 0 !important;
        pointer-events: none !important;
        opacity: 0.42 !important;
        background:
            linear-gradient(90deg, rgba(37, 99, 235, 0.06) 1px, transparent 1px),
            linear-gradient(180deg, rgba(37, 99, 235, 0.05) 1px, transparent 1px) !important;
        background-size: 32px 32px !important;
        mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.72), transparent 85%) !important;
    }

    body.login-page .login-steps-inner,
    body.login-page .login-workflow-inner {
        position: relative !important;
        z-index: 1 !important;
        padding: 38px 16px !important;
    }

    body.login-page .login-steps .login-section-kicker,
    body.login-page .login-workflow .login-section-kicker {
        border-color: rgba(142, 181, 238, 0.84) !important;
        background: rgba(255, 255, 255, 0.88) !important;
        color: #4f46e5 !important;
        box-shadow: 0 12px 26px rgba(31, 80, 146, 0.1), inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
    }

    body.login-page .login-steps-inner h2,
    body.login-page .login-workflow-header h2 {
        color: #102744 !important;
        background: none !important;
        -webkit-text-fill-color: currentColor !important;
        text-shadow: none !important;
    }

    body.login-page .login-section-lead-copy > p,
    body.login-page .login-workflow-header p {
        color: #536985 !important;
    }

    body.login-page .login-steps .login-section-visual,
    body.login-page .login-workflow .login-section-visual {
        border-color: rgba(156, 186, 229, 0.78) !important;
        background: linear-gradient(180deg, #ffffff 0%, #edf5ff 100%) !important;
        box-shadow: 0 22px 42px rgba(31, 80, 146, 0.16), 0 0 0 1px rgba(255, 255, 255, 0.78) inset !important;
    }

    body.login-page .login-steps .login-step-card,
    body.login-page .login-workflow .login-workflow-card {
        border-color: rgba(163, 191, 232, 0.74) !important;
        background:
            radial-gradient(circle at 95% 0%, rgba(56, 189, 248, 0.1), transparent 34%),
            linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 249, 255, 0.98)) !important;
        box-shadow: 0 16px 32px rgba(31, 80, 146, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.86) !important;
    }

    body.login-page .login-steps .login-step-card h3,
    body.login-page .login-workflow .login-workflow-card h3 {
        color: #122844 !important;
    }

    body.login-page .login-steps .login-step-card p,
    body.login-page .login-workflow .login-workflow-card p {
        color: #59708c !important;
    }

    body.login-page .login-steps .login-step-icon,
    body.login-page .login-workflow .login-workflow-icon {
        border-color: rgba(91, 150, 239, 0.36) !important;
        background: linear-gradient(145deg, #eaf3ff, #dfeaff) !important;
        color: #2563eb !important;
        box-shadow: 0 12px 24px rgba(37, 99, 235, 0.12) !important;
    }

    body.login-page .login-help {
        display: block !important;
        position: relative !important;
        z-index: 2 !important;
        border-top: 1px solid rgba(188, 211, 239, 0.82) !important;
        background:
            radial-gradient(circle at 16% 0%, rgba(109, 61, 245, 0.09), transparent 32%),
            radial-gradient(circle at 90% 12%, rgba(56, 189, 248, 0.11), transparent 30%),
            linear-gradient(180deg, #f9fbff 0%, #edf5ff 100%) !important;
        color: #102744 !important;
    }

    body.login-page .login-help-inner {
        position: relative !important;
        z-index: 1 !important;
        max-width: 480px !important;
        padding: 34px 16px 38px !important;
    }

    body.login-page .login-help-header {
        text-align: left !important;
        align-items: flex-start !important;
        margin-bottom: 16px !important;
    }

    body.login-page .login-help-header .login-section-kicker {
        border-color: rgba(142, 181, 238, 0.84) !important;
        background: rgba(255, 255, 255, 0.9) !important;
        color: #4f46e5 !important;
        box-shadow: 0 12px 26px rgba(31, 80, 146, 0.1), inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
    }

    body.login-page .login-help-header h2 {
        margin: 0 0 9px !important;
        color: #102744 !important;
        font-size: clamp(24px, 7vw, 31px) !important;
        line-height: 1.08 !important;
        letter-spacing: -0.035em !important;
        background: none !important;
        -webkit-text-fill-color: currentColor !important;
        text-shadow: none !important;
    }

    body.login-page .login-help-header p {
        max-width: 34rem !important;
        margin: 0 !important;
        color: #536985 !important;
        font-size: 13.75px !important;
        line-height: 1.52 !important;
    }

    body.login-page .login-help-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }

    body.login-page .login-help-item {
        display: grid !important;
        gap: 10px !important;
        padding: 14px !important;
        border-radius: 17px !important;
        border: 1px solid rgba(163, 191, 232, 0.76) !important;
        background:
            radial-gradient(circle at 94% 0%, rgba(56, 189, 248, 0.09), transparent 34%),
            linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(244, 249, 255, 0.99)) !important;
        box-shadow: 0 16px 32px rgba(31, 80, 146, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.86) !important;
    }

    body.login-page .login-help-item-head {
        display: grid !important;
        grid-template-columns: 38px 1fr !important;
        align-items: center !important;
        gap: 10px !important;
    }

    body.login-page .login-help-icon {
        width: 38px !important;
        height: 38px !important;
        border-radius: 13px !important;
        border-color: rgba(91, 150, 239, 0.36) !important;
        background: linear-gradient(145deg, #eaf3ff, #dfeaff) !important;
        color: #2563eb !important;
        box-shadow: 0 12px 24px rgba(37, 99, 235, 0.12) !important;
    }

    body.login-page .login-help-item h3 {
        margin: 0 !important;
        color: #122844 !important;
        font-size: 15.5px !important;
        line-height: 1.2 !important;
    }

    body.login-page .login-help-item p {
        margin: 0 !important;
        color: #59708c !important;
        font-size: 12.8px !important;
        line-height: 1.48 !important;
    }

    body.login-page .login-help-action {
        width: 100% !important;
        min-height: 38px !important;
        justify-content: center !important;
        color: #ffffff !important;
        border: 1px solid rgba(79, 70, 229, 0.42) !important;
        background: linear-gradient(135deg, #2563eb 0%, #6d3df5 100%) !important;
        box-shadow: 0 12px 26px rgba(79, 70, 229, 0.18) !important;
    }
}
