/* MOBILE OVERRIDE ULTRA-AGGRESSIVO - VERSIONE 3.0 */
/* Questo file forza brutalmente il layout mobile su tutti i dispositivi */
/* Specificamente progettato per battere @import responsive.css in style.css */

/* === OVERRIDE BRUTALE CON MASSIMA SPECIFICITÀ === */
/* Queste regole hanno specificità MASSIMA per battere qualsiasi @import */
html body div.desktop-dashboard-container,
html body .desktop-dashboard-container.desktop-dashboard-container,
body div.desktop-dashboard-container,
div.desktop-dashboard-container.desktop-dashboard-container,
.desktop-dashboard-container.desktop-dashboard-container.desktop-dashboard-container,
#main-content .desktop-dashboard-container,
.main-content-wrapper .desktop-dashboard-container {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    height: 0 !important;
    width: 0 !important;
    overflow: hidden !important;
    position: absolute !important;
    left: -9999px !important;
    top: -9999px !important;
    z-index: -999 !important;
    transform: translateX(-100vw) !important;
}

html body div.mobile-dashboard-container,
html body .mobile-dashboard-container.mobile-dashboard-container,
body div.mobile-dashboard-container,
div.mobile-dashboard-container.mobile-dashboard-container,
.mobile-dashboard-container.mobile-dashboard-container.mobile-dashboard-container,
#main-content .mobile-dashboard-container,
.main-content-wrapper .mobile-dashboard-container {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    width: 100% !important;
    overflow: visible !important;
    position: relative !important;
    left: auto !important;
    top: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    z-index: 1 !important;
    transform: none !important;
}

/* === OVERRIDE SPECIFICO PER CONTRASTARE @import responsive.css === */
/* Neutralizza TUTTE le regole .dashboard-container, .stats-row, .welcome-stats */
html body .mobile-dashboard-container .dashboard-container,
body .mobile-dashboard-container .dashboard-container,
.mobile-dashboard-container .dashboard-container.dashboard-container {
    padding: 16px 8px !important;
    border-radius: 12px !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* Override stats-row da responsive.css */
html body .mobile-dashboard-container .stats-row,
body .mobile-dashboard-container .stats-row,
.mobile-dashboard-container .stats-row.stats-row,
html body .mobile-dashboard-container .mobile-stats-grid .stats-row {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    grid-template-rows: repeat(3, 1fr) !important;
    gap: 0.75rem !important;
    margin-bottom: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* Override welcome-stats da responsive.css */
html body .mobile-dashboard-container .welcome-stats,
body .mobile-dashboard-container .welcome-stats,
.mobile-dashboard-container .welcome-stats.welcome-stats {
    display: flex !important;
    justify-content: flex-end !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Override welcome-content da responsive.css */
html body .mobile-dashboard-container .welcome-content,
body .mobile-dashboard-container .welcome-content,
.mobile-dashboard-container .welcome-content.welcome-content {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* === JAVASCRIPT-TRIGGERED CLASSES === */
/* Classi applicate via JavaScript per massima priorità */
.force-mobile-layout .desktop-dashboard-container,
.mobile-enforced .desktop-dashboard-container,
html.force-mobile-layout .desktop-dashboard-container,
html.mobile-enforced .desktop-dashboard-container {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    position: absolute !important;
    left: -9999px !important;
    top: -9999px !important;
    width: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
    z-index: -999 !important;
}

.force-mobile-layout .mobile-dashboard-container,
.mobile-enforced .mobile-dashboard-container,
html.force-mobile-layout .mobile-dashboard-container,
html.mobile-enforced .mobile-dashboard-container {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: 100% !important;
    height: auto !important;
    overflow: visible !important;
    z-index: 1 !important;
    padding: 0 !important;
    margin: 0 !important;
    box-sizing: border-box !important;
}

/* === DUAL VIEW SYSTEM ULTRA-AGGRESSIVE === */
/* Force mobile dual-view on ALL devices */
.desktop-dashboard-container {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    height: 0 !important;
    width: 0 !important;
    overflow: hidden !important;
    position: absolute !important;
    left: -9999px !important;
}

.mobile-dashboard-container {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    width: 100% !important;
    overflow: visible !important;
    position: relative !important;
    left: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    box-sizing: border-box !important;
}

/* === MOBILE DASHBOARD COMPONENTS === */
.mobile-header {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
    color: white !important;
    padding: 1.5rem 1rem !important;
    margin: 0 0.5rem 1rem 0.5rem !important;
    border-radius: 1rem !important;
    text-align: center !important;
    width: calc(100% - 1rem) !important;
    box-sizing: border-box !important;
}

.mobile-welcome h1 {
    font-size: 1.5rem !important;
    margin-bottom: 0.5rem !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
}

.mobile-welcome p {
    font-size: 0.9rem !important;
    opacity: 0.9 !important;
    margin-bottom: 1rem !important;
    line-height: 1.3 !important;
}

.mobile-btn-primary {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(255, 255, 255, 0.2) !important;
    color: white !important;
    padding: 0.75rem 1.5rem !important;
    border-radius: 0.5rem !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 0.9rem !important;
    border: 1px solid rgba(255, 255, 255, 0.3) !important;
    backdrop-filter: blur(10px) !important;
}

/* Mobile Stats Section */
.mobile-stats-section {
    margin: 0 0.5rem 1.5rem 0.5rem !important;
    width: calc(100% - 1rem) !important;
    box-sizing: border-box !important;
}

.mobile-stats-container {
    display: flex !important;
    justify-content: flex-end !important;
    width: 100% !important;
}

.mobile-stats-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: 1fr 1fr 1fr !important;
    gap: 0.75rem !important;
    width: 95% !important;
    max-width: 320px !important;
}

.mobile-stat-card {
    background: white !important;
    border-radius: 0.75rem !important;
    padding: 1rem 0.5rem !important;
    text-align: center !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
    border: 1px solid #f0f0f0 !important;
    min-height: 80px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
}

.mobile-stat-icon {
    font-size: 1.5rem !important;
    margin-bottom: 0.25rem !important;
}

.mobile-stat-number {
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    color: #333 !important;
    margin-bottom: 0.125rem !important;
    line-height: 1 !important;
}

.mobile-stat-label {
    font-size: 0.7rem !important;
    color: #666 !important;
    font-weight: 600 !important;
    line-height: 1.1 !important;
    text-align: center !important;
}

/* Mobile Actions */
.mobile-actions-section {
    margin: 0 0.5rem 1.5rem 0.5rem !important;
    width: calc(100% - 1rem) !important;
    box-sizing: border-box !important;
}

.mobile-actions-section h2 {
    font-size: 1.2rem !important;
    margin-bottom: 1rem !important;
    color: #333 !important;
    font-weight: 600 !important;
}

.mobile-actions-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 0.75rem !important;
}

.mobile-action-card {
    background: white !important;
    border-radius: 0.75rem !important;
    padding: 1rem !important;
    text-decoration: none !important;
    color: inherit !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
    border: 1px solid #f0f0f0 !important;
    min-height: 100px !important;
    transition: transform 0.2s ease !important;
}

.mobile-action-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
}

.mobile-action-icon {
    font-size: 1.8rem !important;
    margin-bottom: 0.5rem !important;
}

.mobile-action-text h3 {
    font-size: 0.85rem !important;
    margin-bottom: 0.25rem !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
}

.mobile-action-text p {
    font-size: 0.7rem !important;
    opacity: 0.7 !important;
    margin: 0 !important;
}

/* Forza tutto a essere mobile sempre */
.dashboard-container {
    display: block !important;
    grid-template-columns: none !important;
    grid-template-rows: none !important;
    gap: 0 !important;
    padding: 8px !important;
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    box-sizing: border-box !important;
}

/* Welcome section */
.welcome-section {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
    border-radius: 16px !important;
    padding: 24px 16px !important;
    margin-bottom: 20px !important;
    color: white !important;
    width: calc(100vw - 16px) !important;
    max-width: calc(100vw - 16px) !important;
    box-sizing: border-box !important;
}

.welcome-content {
    display: block !important;
    text-align: center !important;
    margin-bottom: 24px !important;
}

.welcome-text h1 {
    font-size: 1.8rem !important;
    margin-bottom: 8px !important;
    line-height: 1.2 !important;
}

.welcome-text p {
    font-size: 0.95rem !important;
    margin-bottom: 16px !important;
    opacity: 0.9 !important;
}

.welcome-actions {
    margin-bottom: 24px !important;
    text-align: center !important;
}

/* Stats grid - FORZA 2x3 allineato a destra */
.welcome-stats {
    display: flex !important;
    justify-content: flex-end !important;
    width: 100% !important;
}

.stats-row,
.stats-row.stats-desktop-right {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: 1fr 1fr 1fr !important;
    gap: 12px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
}

.stat-item {
    background: white !important;
    border-radius: 12px !important;
    padding: 16px 8px !important;
    text-align: center !important;
    min-height: 80px !important;
    min-width: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
    transition: none !important;
    color: #333 !important;
}

.stat-icon {
    font-size: 1.8rem !important;
    margin-bottom: 4px !important;
    display: block !important;
}

.stat-number {
    font-size: 1.6rem !important;
    font-weight: 700 !important;
    margin-bottom: 2px !important;
    display: block !important;
}

.stat-label {
    font-size: 0.8rem !important;
    opacity: 0.7 !important;
    display: block !important;
}

/* Quick actions */
.quick-actions {
    margin-bottom: 20px !important;
    padding: 0 4px !important;
}

.quick-actions h2 {
    font-size: 1.3rem !important;
    margin-bottom: 12px !important;
    color: #333 !important;
}

.actions-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
    width: 100% !important;
}

.action-card {
    padding: 16px 12px !important;
    border-radius: 12px !important;
    text-decoration: none !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    min-height: 100px !important;
    transition: none !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
    color: inherit !important;
}

.action-icon {
    font-size: 1.8rem !important;
    margin-bottom: 8px !important;
}

.action-content h3 {
    font-size: 0.9rem !important;
    margin-bottom: 4px !important;
    line-height: 1.2 !important;
}

.action-content p {
    font-size: 0.75rem !important;
    opacity: 0.8 !important;
    margin: 0 !important;
}

.action-arrow {
    display: none !important;
}

/* Dashboard grid */
.dashboard-grid {
    display: block !important;
    grid-template-columns: none !important;
    gap: 0 !important;
    width: 100% !important;
}

.dashboard-card {
    margin-bottom: 20px !important;
    border-radius: 12px !important;
    padding: 16px !important;
    width: calc(100vw - 16px) !important;
    max-width: calc(100vw - 16px) !important;
    box-sizing: border-box !important;
    background: white !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
}

/* Button styles */
.btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 12px 20px !important;
    border-radius: 8px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    transition: none !important;
}

.btn-primary,
.btn-cta {
    background: #667eea !important;
    color: white !important;
    border: none !important;
}

.btn svg {
    width: 16px !important;
    height: 16px !important;
    margin-right: 8px !important;
}

/* Card styles */
.card-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 16px !important;
}

.card-header h2 {
    font-size: 1.2rem !important;
    margin: 0 !important;
    color: #333 !important;
}

.card-link {
    font-size: 0.9rem !important;
    color: #667eea !important;
    text-decoration: none !important;
}

.card-content {
    color: #666 !important;
    line-height: 1.5 !important;
}

/* === OVERRIDE STATS SPECIFICO PER BATTERE RESPONSIVE.CSS === */
/* Neutralizza completamente le regole stats di responsive.css */
html body .mobile-dashboard-container .mobile-stats-grid,
body .mobile-dashboard-container .mobile-stats-grid,
.mobile-dashboard-container .mobile-stats-grid {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    grid-template-rows: repeat(3, 1fr) !important;
    gap: 0.75rem !important;
    margin: 0 0.5rem 1rem auto !important;
    width: calc(100% - 1rem) !important;
    max-width: 100% !important;
    justify-self: end !important;
    box-sizing: border-box !important;
}

/* Override specifico per .stats-row che viene da responsive.css */
html body .mobile-dashboard-container .stats-row,
body .mobile-dashboard-container .stats-row,
.mobile-dashboard-container .stats-row,
.mobile-stats-grid .stats-row {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    grid-template-rows: repeat(3, 1fr) !important;
    gap: 0.75rem !important;
    margin-bottom: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* Override per .stat-item specifico mobile */
html body .mobile-dashboard-container .mobile-stat-item,
body .mobile-dashboard-container .mobile-stat-item,
.mobile-dashboard-container .mobile-stat-item,
.mobile-stats-grid .mobile-stat-item {
    background: #fff !important;
    color: #312e81 !important;
    border-radius: 0.75rem !important;
    padding: 1rem 0.5rem !important;
    min-width: auto !important;
    min-height: 80px !important;
    text-align: center !important;
    box-shadow: 0 2px 8px rgba(99,102,241,0.1) !important;
    transition: all 0.2s ease !important;
    font-size: 0.85rem !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.mobile-stat-item:hover {
    box-shadow: 0 4px 12px rgba(99,102,241,0.15) !important;
    transform: translateY(-2px) !important;
}

/* Neutralizza qualsiasi regola .welcome-stats e .welcome-content */
html body .mobile-dashboard-container .welcome-stats,
body .mobile-dashboard-container .welcome-stats,
.mobile-dashboard-container .welcome-stats {
    display: flex !important;
    justify-content: flex-end !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

html body .mobile-dashboard-container .welcome-content,
body .mobile-dashboard-container .welcome-content,
.mobile-dashboard-container .welcome-content {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* === OVERRIDE SEZIONI SPECIFICHE MOBILE === */
/* Per ulteriori override specifici delle sezioni, aggiungere qui sotto */

/* === FINAL ULTIMATE SOLUTION - MAXIMUM SPECIFICITY === */
/* VERSIONE 4.0 - Soluzione definitiva per battere @import responsive.css */

/* TRIPLE SELECTOR SPECIFICITY - GUARANTEED TO WIN AGAINST @import */
html body div.desktop-dashboard-container.desktop-dashboard-container.desktop-dashboard-container,
html body .desktop-dashboard-container.desktop-dashboard-container.desktop-dashboard-container,
body div.desktop-dashboard-container.desktop-dashboard-container.desktop-dashboard-container,
.desktop-dashboard-container.desktop-dashboard-container.desktop-dashboard-container.desktop-dashboard-container {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    height: 0 !important;
    width: 0 !important;
    overflow: hidden !important;
    position: absolute !important;
    left: -9999px !important;
    top: -9999px !important;
    z-index: -999 !important;
    transform: translateX(-100vw) translateY(-100vh) !important;
    clip: rect(0,0,0,0) !important;
    pointer-events: none !important;
}

html body div.mobile-dashboard-container.mobile-dashboard-container.mobile-dashboard-container,
html body .mobile-dashboard-container.mobile-dashboard-container.mobile-dashboard-container,
body div.mobile-dashboard-container.mobile-dashboard-container.mobile-dashboard-container,
.mobile-dashboard-container.mobile-dashboard-container.mobile-dashboard-container.mobile-dashboard-container {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    width: 100% !important;
    overflow: visible !important;
    position: relative !important;
    left: auto !important;
    top: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    z-index: 1 !important;
    transform: none !important;
    clip: auto !important;
    pointer-events: auto !important;
}

/* OVERRIDE EVERY POSSIBLE RESPONSIVE.CSS RULE WITH MAXIMUM SPECIFICITY */
