/* ==========================================================
   Forsur – Client Portal Navigation
   Desktop-first | 2025 / 2026 SaaS UI
   ========================================================== */

/* Root nav */
#forsur-client-menu {
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    background: transparent !important;
    padding: 0 !important;
}

/* ----------------------------------------------------------
   NAV LINKS
   ---------------------------------------------------------- */
#forsur-client-menu .navbar-nav {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

#forsur-client-menu .nav-link {
    padding: 8px 14px !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    color: #1f2937 !important;
    background: transparent !important;
    border-radius: 8px !important;
    border: 1px solid transparent !important;
    transition:
            background-color 0.15s ease,
            box-shadow 0.15s ease,
            transform 0.12s ease !important;
}

/* Hover */
#forsur-client-menu .nav-link:hover {
    background-color: #f3f4f6 !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.06) !important;
    transform: translateY(-1px) !important;
}

/* Active */
#forsur-client-menu .nav-link.active {
    background-color: #ffffff !important;
    border-color: #e5e7eb !important;
    box-shadow:
            0 1px 2px rgba(0,0,0,0.06),
            0 0 0 2px rgba(59,130,246,0.18) !important;
}

/* Pressed */
#forsur-client-menu .nav-link:active {
    transform: scale(0.97) !important;
}

/* ----------------------------------------------------------
   HAMBURGER (MOBILE ONLY)
   ---------------------------------------------------------- */
#forsur-client-menu .navbar-toggler {
    border: none !important;
    padding: 6px !important;
}

#forsur-client-menu .navbar-toggler-icon {
    filter: invert(25%) !important;
}

/* Hide hamburger on desktop */
@media (min-width: 992px) {
    #forsur-client-menu .navbar-toggler {
        display: none !important;
    }
}

/* ----------------------------------------------------------
   COLLAPSE BEHAVIOR
   ---------------------------------------------------------- */
@media (min-width: 992px) {
    #forsurMenu {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
    }

    #forsurMenu .navbar-nav {
        flex-direction: row !important;
        margin-left: auto !important;
    }

    .row.padd0 {
        display: flex !important;
        align-items: center !important;
    }
}

/* Mobile: stacked menu */
@media (max-width: 991px) {
    #forsurMenu .navbar-nav {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 6px !important;
        padding-top: 10px !important;
    }
}

/* ==========================================================
   Forsur – Client Dashboard Cards
   Unified Grid System (Portal-only)
   ========================================================== */
/* ==========================================================
   Forsur – Client Dashboard & Portal Cards (Mobile Collapse Fix)
   ========================================================== */

/* ----------------------------------------------------------
   GRID & BASE CARDS
   ---------------------------------------------------------- */
#client-portal-content .portal-card-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 24px !important;
    align-items: stretch !important;
    margin-bottom: 32px !important;
}

#client-portal-content .portal-card-grid .card {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 16px !important;
    border: 1px solid #e5e7eb !important;
    background: #ffffff !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.05) !important;
    transition: transform 0.15s ease, box-shadow 0.15s ease !important;
}

#client-portal-content .portal-card-grid .card:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 18px rgba(0,0,0,0.08) !important;
}

/* ----------------------------------------------------------
   SUMMARY CARDS
   ---------------------------------------------------------- */
#client-portal-content .portal-summary-card {
    text-align: center !important;
}

#client-portal-content .portal-summary-card .card-header {
    background: transparent !important;
    border-bottom: 1px solid #f1f5f9 !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    color: #6b7280 !important;
}

#client-portal-content .portal-summary-card h2 {
    font-size: 2rem !important;
    font-weight: 700 !important;
    margin: 0 !important;
    color: #111827 !important;
}

/* ----------------------------------------------------------
   INSTALLATION CARDS
   ---------------------------------------------------------- */
#client-portal-content #client-installationcards .card-header {
    background: transparent !important;
    border-bottom: 1px solid #f1f5f9 !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    color: #6b7280 !important;
}

#client-portal-content #client-installationcards .card-img-top {
    width: 100% !important;
    height: 160px !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
    background-color: #f3f4f6 !important;
}

#client-portal-content #client-installationcards .card-body {
    padding: 14px !important;
    font-size: 0.8rem !important;
    color: #374151 !important;
}

/* ----------------------------------------------------------
   INSTALLATION CARD FOOTER
   ---------------------------------------------------------- */
.portal-installation-card .card-footer {
    background: #fafafa !important;
    border-top: 1px solid #f1f5f9 !important;
    padding: 6px 8px !important;
    margin: 0 !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 4px !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    transition: opacity 0.25s ease !important;
}

.portal-installation-card .card-footer img {
    max-height: 36px !important; /* Match button height */
    height: auto !important;
    width: auto !important;
    vertical-align: middle !important;
}

.portal-installation-card .card-footer button {
    height: 36px !important;
    margin: 0 !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
 /*   color: #111827 !important;
    background: #f59e0b !important; */
    border-radius: 8px !important;
    border: none !important;
    padding: 0 12px !important;
    transition: background 0.2s ease, box-shadow 0.15s ease !important;
}

.portal-installation-card .card-footer button:hover {
    background: #fbbf24 !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.06) !important;
}

/* ----------------------------------------------------------
   MOBILE COLLAPSE ONLY
   ---------------------------------------------------------- */
@media (max-width: 768px) {

    #client-portal-content .portal-card-grid {
        grid-template-columns: 1fr !important;
        justify-items: center !important;
    }

    #client-portal-content .portal-card-grid .card {
        max-width: 320px !important;
        width: 100% !important;
    }

    /* Collapsible content hidden by default */
    .portal-installation-card .card-collapsible-content {
        display: none !important;
        width: 100% !important;
        overflow: hidden !important;
        padding: 0 12px 12px 12px !important;
    }

    .portal-installation-card.expanded .card-collapsible-content {
        display: block !important;
    }

    /* Footer hidden when collapsed, visible when expanded */
    .portal-installation-card .card-footer {
        visibility: hidden !important;
        opacity: 0 !important;
    }

    .portal-installation-card.expanded .card-footer {
        visibility: visible !important;
        opacity: 1 !important;
    }

    /* Toggle arrow only visible on mobile */
    .portal-installation-card .mobile-toggle {
        cursor: pointer !important;
        user-select: none !important;
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
    }

    .portal-installation-card .toggle-arrow {
        display: inline-block !important;
        font-size: 1.2em !important;
        transition: transform 0.2s ease !important;
    }

    .portal-installation-card.expanded .toggle-arrow {
        transform: rotate(180deg) !important;
    }
}

/* ----------------------------------------------------------
   DESKTOP & TABLET: always expanded, hide arrows
   ---------------------------------------------------------- */
@media (min-width: 769px) {
    .portal-installation-card .card-collapsible-content {
        display: block !important;
    }

    .portal-installation-card .card-footer {
        visibility: visible !important;
        opacity: 1 !important;
    }

    .portal-installation-card .toggle-arrow {
        display: none !important;
    }

    .portal-installation-card .mobile-toggle span.toggle-arrow {
        display: none !important; /* hide only arrow, keep header visible */
    }

    .portal-installation-card .mobile-toggle {
        cursor: default !important;
        display: flex !important;
        justify-content: flex-start !important;
        align-items: center !important;
    }
}



/* Analysis Section – Documentation style */
.analysis-section {
    margin: 32px auto !important;
    max-width: 980px !important;
    padding: 0 16px !important;
}

.analysis-title {
    font-size: 1.75rem !important;
    font-weight: 700 !important;
    margin-bottom: 24px !important;
    color: #111827 !important;
}

/* Controls */
.analysis-controls {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 16px !important;
    align-items: flex-end !important;
    margin-bottom: 24px !important;
}

.analysis-control {
    display: flex !important;
    flex-direction: column !important;
    min-width: 160px !important;
}

/* Location select */
.analysis-select {
    margin-bottom: 16px !important;
}

.analysis-select select {
    width: auto !important;
    min-width: 200px !important;
}

/* Chart container – fluid, responsive */
.analysis-chart {
    width: 100% !important;
    min-height: 400px !important;
    border-radius: 12px !important;
    background: #f9fafb !important;
    border: 1px solid #e5e7eb !important;
 /*   padding: 12px !important; */
    margin-bottom: 32px !important;
}

/* Recent documents */
.recent-documents {
    border-top: 1px solid #e5e7eb !important;
    padding-top: 16px !important;
}

.recent-documents h2 {
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    margin-bottom: 12px !important;
    color: #111827 !important;
}

/* Mobile adjustments */
@media (max-width: 768px) {
    .analysis-controls {
        flex-direction: column !important;
        gap: 12px !important;
    }

    .analysis-control {
        width: 100% !important;
    }

    .analysis-chart {
        min-height: 300px !important;
    }
}
