
/* =========================================================
   Fix definitivo: mobile first, KPIs premium, gamificação,
   denúncia sem corte e limite visual consistente
   ========================================================= */

/* KPIs superiores cinza do dashboard freelancer/cliente */
.freelancer-dashboard-page > .grid.cards-3 > .card,
.client-dashboard-page > .grid.cards-3 > .card,
.dashboard-kpi-grid > .card,
.metric-card,
.stat-card {
    background:
        radial-gradient(circle at 12% 10%, rgba(124,58,237,.20), transparent 36%),
        linear-gradient(145deg, rgba(15, 23, 42, .98), rgba(17, 24, 39, .94)) !important;
    border: 1px solid rgba(59, 130, 246, .28) !important;
    color: #eef4ff !important;
    box-shadow: 0 18px 48px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.045) !important;
}

.freelancer-dashboard-page > .grid.cards-3 > .card::before,
.client-dashboard-page > .grid.cards-3 > .card::before,
.dashboard-kpi-grid > .card::before,
.metric-card::before,
.stat-card::before {
    content: "";
    display: block;
    height: 3px;
    border-radius: 999px;
    margin-bottom: 12px;
    background: linear-gradient(90deg, #7c3aed, #2563eb, #22c55e);
    opacity: .85;
}

.freelancer-dashboard-page > .grid.cards-3 > .card *,
.client-dashboard-page > .grid.cards-3 > .card *,
.dashboard-kpi-grid > .card *,
.metric-card *,
.stat-card * {
    color: inherit !important;
}

.freelancer-dashboard-page > .grid.cards-3 > .card span,
.client-dashboard-page > .grid.cards-3 > .card span,
.dashboard-kpi-grid > .card span,
.metric-card span,
.stat-card span,
.freelancer-dashboard-page > .grid.cards-3 > .card .muted,
.client-dashboard-page > .grid.cards-3 > .card .muted {
    color: rgba(191, 219, 254, .78) !important;
}

.freelancer-dashboard-page > .grid.cards-3 > .card strong,
.client-dashboard-page > .grid.cards-3 > .card strong,
.dashboard-kpi-grid > .card strong,
.metric-card strong,
.stat-card strong {
    color: #ffffff !important;
}

/* Gamificação encaixotada igual ao restante do layout */
.freelancer-dashboard-page .gamification-dashboard-widget,
.client-dashboard-page .gamification-dashboard-widget,
.gamification-dashboard-widget.dashboard-contained {
    width: min(100%, var(--container, 1180px));
    max-width: var(--container, 1180px);
    margin: 28px auto 34px !important;
    padding: 0 0 !important;
}

.gamification-inline-card {
    border-radius: 22px !important;
    padding: 26px !important;
    background:
        radial-gradient(circle at 12% 10%, rgba(124,58,237,.28), transparent 38%),
        linear-gradient(145deg, rgba(15,23,42,.98), rgba(17,24,39,.94)) !important;
    border: 1px solid rgba(139,92,246,.38) !important;
    box-shadow: 0 18px 52px rgba(0,0,0,.35) !important;
    overflow: hidden;
}

/* Propostas recentes com respiro lateral */
.freelancer-recent-proposals-card,
.client-recent-proposals-card,
.card:has(.section-head h2) {
    box-sizing: border-box;
}

.freelancer-recent-proposals-card .list-row,
.client-recent-proposals-card .list-row {
    padding: 18px 20px !important;
    margin: 14px 0 !important;
    border-radius: 16px !important;
}

/* Página do projeto: sidebar nunca deve cortar denúncia */
.project-detail-page {
    overflow: visible !important;
}

.project-detail-page .project-layout {
    align-items: flex-start !important;
    overflow: visible !important;
}

.proposal-sidebar-card,
.project-detail-page .sticky-card {
    position: sticky;
    top: 92px;
    align-self: flex-start;
    max-height: calc(100vh - 120px);
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding: 24px !important;
    scrollbar-width: thin;
}

.proposal-sidebar-card .report-box,
.project-detail-page .report-box {
    overflow: visible !important;
    max-height: none !important;
    padding: 14px !important;
    margin-top: 12px !important;
}

.proposal-sidebar-card .report-box textarea,
.project-detail-page .report-box textarea {
    min-height: 96px;
    resize: vertical;
}

.proposal-sidebar-card .social-trust-actions,
.project-detail-page .social-trust-actions {
    padding-bottom: 10px;
}

/* Uso mensal: garantir leitura e espaçamento */
.plan-usage-box {
    padding: 18px !important;
    border-radius: 18px !important;
}

.plan-usage-box .usage-line {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: 12px 0 8px !important;
}

.plan-usage-box .usage-line strong {
    color: #ffffff !important;
    font-weight: 900 !important;
}

/* Mobile first */
@media (max-width: 900px) {
    .project-detail-page .project-layout {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 22px !important;
    }

    .proposal-sidebar-card,
    .project-detail-page .sticky-card {
        position: static !important;
        max-height: none !important;
        overflow: visible !important;
        width: 100% !important;
        top: auto !important;
    }

    .project-detail-page .card-project {
        width: 100% !important;
    }

    .proposal-sidebar-card .report-box,
    .project-detail-page .report-box {
        display: block;
    }
}

@media (max-width: 768px) {
    .freelancer-dashboard-page,
    .client-dashboard-page,
    .project-detail-page {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    .freelancer-dashboard-page > .grid.cards-3,
    .client-dashboard-page > .grid.cards-3,
    .dashboard-kpi-grid {
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }

    .gamification-inline-card {
        padding: 20px !important;
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .gamification-inline-actions {
        display: grid !important;
        grid-template-columns: 1fr !important;
        width: 100%;
    }

    .gamification-inline-actions .btn {
        width: 100%;
    }

    .proposal-sidebar-card,
    .project-detail-page .sticky-card {
        padding: 18px !important;
    }

    .social-trust-actions .btn,
    .report-box .btn {
        width: 100%;
    }
}

@media (max-width: 480px) {
    .plan-usage-box .usage-line {
        align-items: flex-start;
        flex-direction: column;
        gap: 4px;
    }

    .project-detail-page h1 {
        font-size: clamp(26px, 8vw, 36px) !important;
    }
}
