
/* =========================================================
   Páginas dinâmicas profissionais + correção de cards upsell
   ========================================================= */

.dynamic-public-page {
    padding-top: 58px !important;
    padding-bottom: 76px !important;
}

.dynamic-page-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, .36fr);
    gap: 28px;
    align-items: end;
    padding: clamp(30px, 5vw, 58px) !important;
    border-radius: 28px !important;
    background:
        radial-gradient(circle at 14% 10%, rgba(124,58,237,.25), transparent 34%),
        radial-gradient(circle at 84% 18%, rgba(34,197,94,.12), transparent 34%),
        linear-gradient(145deg, rgba(15,23,42,.98), rgba(17,24,39,.94)) !important;
    border: 1px solid rgba(139,92,246,.30) !important;
    box-shadow: 0 24px 70px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.045) !important;
}

.dynamic-page-hero h1 {
    max-width: 940px;
    margin: 18px 0 18px;
    font-size: clamp(40px, 6vw, 78px);
    line-height: .98;
    letter-spacing: -0.065em;
}

.dynamic-page-lead {
    max-width: 820px;
    font-size: clamp(17px, 1.8vw, 22px);
    line-height: 1.58;
    color: rgba(219,234,254,.86);
}

.dynamic-page-summary {
    padding: 22px;
    border-radius: 22px;
    background: rgba(255,255,255,.045);
    border: 1px solid rgba(255,255,255,.08);
}

.dynamic-page-summary span,
.dynamic-page-summary strong {
    display: block;
    overflow-wrap: anywhere;
}

.dynamic-page-summary span {
    color: rgba(191,219,254,.72);
    margin-bottom: 8px;
}

.dynamic-page-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 28px;
    align-items: start;
    margin-top: 28px;
}

.dynamic-page-card,
.dynamic-aside-card {
    border-radius: 26px !important;
    background:
        radial-gradient(circle at 12% 10%, rgba(124,58,237,.16), transparent 34%),
        linear-gradient(145deg, rgba(15,23,42,.98), rgba(17,24,39,.94)) !important;
    border: 1px solid rgba(139,92,246,.24) !important;
    box-shadow: 0 20px 58px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.04) !important;
}

.dynamic-page-card {
    padding: clamp(28px, 4vw, 48px) !important;
}

.dynamic-page-aside {
    display: grid;
    gap: 18px;
    position: sticky;
    top: 110px;
}

.dynamic-aside-card {
    padding: 24px !important;
}

.aside-links {
    display: grid;
    gap: 10px;
    margin-top: 18px;
}

.aside-links a {
    padding: 12px 14px;
    border-radius: 14px;
    text-decoration: none;
    color: rgba(226,232,240,.88);
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
}

.aside-links a:hover {
    border-color: rgba(139,92,246,.55);
    color: #fff;
}

.dynamic-content-pro {
    font-size: 16px;
    line-height: 1.78;
    color: rgba(226,232,240,.88);
}

.dynamic-content-pro h2 {
    margin: 0 0 18px;
    font-size: clamp(26px, 3vw, 38px);
    line-height: 1.12;
    letter-spacing: -0.04em;
    color: #fff;
}

.dynamic-content-pro h3 {
    color: #fff;
    margin: 8px 0 10px;
}

.dynamic-content-pro p {
    margin: 0 0 18px;
    color: rgba(219,234,254,.84);
}

.dynamic-content-pro ul {
    display: grid;
    gap: 10px;
    padding-left: 0;
    list-style: none;
}

.dynamic-content-pro li {
    position: relative;
    padding-left: 26px;
    color: rgba(226,232,240,.86);
}

.dynamic-content-pro li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: #22c55e;
    font-weight: 900;
}

.content-block {
    padding: 28px;
    border-radius: 22px;
    background: rgba(255,255,255,.035);
    border: 1px solid rgba(255,255,255,.075);
    margin-bottom: 22px;
}

.content-block.two-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px;
}

.dynamic-steps {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.dynamic-steps > div {
    padding: 22px;
    border-radius: 20px;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
}

.dynamic-steps strong {
    display: inline-grid;
    place-items: center;
    width: 46px;
    height: 46px;
    border-radius: 16px;
    background: linear-gradient(135deg, #7c3aed, #2563eb);
    color: #fff;
    margin-bottom: 14px;
}

/* Corrige cards encavalados em /dashboard/freelancer/upsell */
.dashboard-upsell-page .metric-grid,
.upsell-page .metric-grid,
.growth-upsell-page .metric-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.dashboard-upsell-page .metric-card,
.upsell-page .metric-card,
.growth-upsell-page .metric-card,
.metric-card {
    min-height: 110px;
    padding: 20px 22px !important;
    display: grid !important;
    gap: 8px !important;
    align-content: center;
    overflow: hidden;
}

.dashboard-upsell-page .metric-card span,
.dashboard-upsell-page .metric-card strong,
.upsell-page .metric-card span,
.upsell-page .metric-card strong,
.growth-upsell-page .metric-card span,
.growth-upsell-page .metric-card strong,
.metric-card span,
.metric-card strong {
    display: block !important;
    line-height: 1.35 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
}

.metric-card strong {
    font-size: clamp(18px, 2vw, 24px);
}

@media (max-width: 1040px) {
    .dynamic-page-layout,
    .dynamic-page-hero {
        grid-template-columns: 1fr;
    }

    .dynamic-page-aside {
        position: static;
    }
}

@media (max-width: 780px) {
    .dynamic-steps,
    .content-block.two-columns,
    .dashboard-upsell-page .metric-grid,
    .upsell-page .metric-grid,
    .growth-upsell-page .metric-grid {
        grid-template-columns: 1fr;
    }

    .dynamic-public-page {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    .dynamic-page-hero,
    .dynamic-page-card,
    .dynamic-aside-card,
    .content-block {
        padding: 22px !important;
    }

    .dynamic-page-hero h1 {
        font-size: clamp(34px, 11vw, 54px);
    }

    .dynamic-aside-card .hero-actions,
    .dynamic-aside-card .btn {
        width: 100%;
    }
}


/* Remoção de textos internos públicos */
.dynamic-page-hero {
    grid-template-columns: 1fr !important;
}

.dynamic-page-summary:empty,
.dynamic-page-summary[hidden] {
    display: none !important;
}
