/*!
 * Startvex consolidated styles
 */


/* Utility helpers */
.startvex-select-primary {
    background-color: #004085;
    color: #ffffff;
}

.startvex-select-primary:focus {
    color: #ffffff;
}

.startvex-select-primary option {
    color: #000000;
}

.startvex-scroll-300 {
    height: 300px;
    overflow-y: auto;
    overflow-x: hidden;
}

.startvex-scroll-380 {
    max-height: 380px;
    overflow-y: auto;
    overflow-x: hidden;
}

.startvex-scroll-450 {
    max-height: 450px;
    overflow-y: auto;
    overflow-x: hidden;
}

.startvex-scroll-thin {
    max-height: 70px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: #ccc transparent;
}

.startvex-scroll-thin::-webkit-scrollbar {
    width: 6px;
}

.startvex-scroll-thin::-webkit-scrollbar-thumb {
    background-color: #ccc;
    border-radius: 8px;
}

.startvex-scroll-thin::-webkit-scrollbar-track {
    background-color: transparent;
}

.startvex-h-0 {
    height: 0;
}

.startvex-h-60 {
    height: 60px;
}

.startvex-min-h-400 {
    min-height: 400px;
}

.startvex-min-w-400 {
    min-width: 400px;
}

.startvex-size-0 {
    width: 0;
    height: 0;
    overflow: hidden;
}

.startvex-avatar-80 {
    width: 80px !important;
    height: 80px !important;
    display: inline-block;
    overflow: hidden;
    border-radius: 10px;
    flex-shrink: 0;
}

.startvex-img-cover {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.startvex-img-contain {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.startvex-img-contain-400 {
    width: 100%;
    max-height: 400px;
    object-fit: contain;
}

.startvex-spinner-lg {
    width: 3rem;
    height: 3rem;
}

.startvex-fs-10 {
    font-size: 10px;
}

.startvex-fs-85 {
    font-size: 0.85rem;
}

.startvex-bg-night {
    background-color: #101827;
}

.startvex-bg-night-2 {
    background-color: #1F2937;
}

.startvex-bg-slate-4848 {
    background-color: #484848;
    border-color: #484848;
}

.startvex-modal-max-420 {
    max-width: 420px;
}

.startvex-modal-max-460 {
    max-width: 460px;
}

.startvex-icon-square-48 {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #ffffff;
}

.startvex-icon-square-40 {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f8fafc;
}

.startvex-logo-48 {
    height: 48px;
    width: auto;
}

.startvex-logo-100 {
    width: 100px;
    height: 100px;
}

.startvex-scrollable-tabs {
    height: 300px;
    overflow-y: auto;
    overflow-x: hidden;
}

.startvex-progress-placeholder {
    display: inline-block;
}


/* Percentage width helpers */
.startvex-width-0 {
    width: 0% !important;
}
.startvex-width-1 {
    width: 1% !important;
}
.startvex-width-2 {
    width: 2% !important;
}
.startvex-width-3 {
    width: 3% !important;
}
.startvex-width-4 {
    width: 4% !important;
}
.startvex-width-5 {
    width: 5% !important;
}
.startvex-width-6 {
    width: 6% !important;
}
.startvex-width-7 {
    width: 7% !important;
}
.startvex-width-8 {
    width: 8% !important;
}
.startvex-width-9 {
    width: 9% !important;
}
.startvex-width-10 {
    width: 10% !important;
}
.startvex-width-11 {
    width: 11% !important;
}
.startvex-width-12 {
    width: 12% !important;
}
.startvex-width-13 {
    width: 13% !important;
}
.startvex-width-14 {
    width: 14% !important;
}
.startvex-width-15 {
    width: 15% !important;
}
.startvex-width-16 {
    width: 16% !important;
}
.startvex-width-17 {
    width: 17% !important;
}
.startvex-width-18 {
    width: 18% !important;
}
.startvex-width-19 {
    width: 19% !important;
}
.startvex-width-20 {
    width: 20% !important;
}
.startvex-width-21 {
    width: 21% !important;
}
.startvex-width-22 {
    width: 22% !important;
}
.startvex-width-23 {
    width: 23% !important;
}
.startvex-width-24 {
    width: 24% !important;
}
.startvex-width-25 {
    width: 25% !important;
}
.startvex-width-26 {
    width: 26% !important;
}
.startvex-width-27 {
    width: 27% !important;
}
.startvex-width-28 {
    width: 28% !important;
}
.startvex-width-29 {
    width: 29% !important;
}
.startvex-width-30 {
    width: 30% !important;
}
.startvex-width-31 {
    width: 31% !important;
}
.startvex-width-32 {
    width: 32% !important;
}
.startvex-width-33 {
    width: 33% !important;
}
.startvex-width-34 {
    width: 34% !important;
}
.startvex-width-35 {
    width: 35% !important;
}
.startvex-width-36 {
    width: 36% !important;
}
.startvex-width-37 {
    width: 37% !important;
}
.startvex-width-38 {
    width: 38% !important;
}
.startvex-width-39 {
    width: 39% !important;
}
.startvex-width-40 {
    width: 40% !important;
}
.startvex-width-41 {
    width: 41% !important;
}
.startvex-width-42 {
    width: 42% !important;
}
.startvex-width-43 {
    width: 43% !important;
}
.startvex-width-44 {
    width: 44% !important;
}
.startvex-width-45 {
    width: 45% !important;
}
.startvex-width-46 {
    width: 46% !important;
}
.startvex-width-47 {
    width: 47% !important;
}
.startvex-width-48 {
    width: 48% !important;
}
.startvex-width-49 {
    width: 49% !important;
}
.startvex-width-50 {
    width: 50% !important;
}
.startvex-width-51 {
    width: 51% !important;
}
.startvex-width-52 {
    width: 52% !important;
}
.startvex-width-53 {
    width: 53% !important;
}
.startvex-width-54 {
    width: 54% !important;
}
.startvex-width-55 {
    width: 55% !important;
}
.startvex-width-56 {
    width: 56% !important;
}
.startvex-width-57 {
    width: 57% !important;
}
.startvex-width-58 {
    width: 58% !important;
}
.startvex-width-59 {
    width: 59% !important;
}
.startvex-width-60 {
    width: 60% !important;
}
.startvex-width-61 {
    width: 61% !important;
}
.startvex-width-62 {
    width: 62% !important;
}
.startvex-width-63 {
    width: 63% !important;
}
.startvex-width-64 {
    width: 64% !important;
}
.startvex-width-65 {
    width: 65% !important;
}
.startvex-width-66 {
    width: 66% !important;
}
.startvex-width-67 {
    width: 67% !important;
}
.startvex-width-68 {
    width: 68% !important;
}
.startvex-width-69 {
    width: 69% !important;
}
.startvex-width-70 {
    width: 70% !important;
}
.startvex-width-71 {
    width: 71% !important;
}
.startvex-width-72 {
    width: 72% !important;
}
.startvex-width-73 {
    width: 73% !important;
}
.startvex-width-74 {
    width: 74% !important;
}
.startvex-width-75 {
    width: 75% !important;
}
.startvex-width-76 {
    width: 76% !important;
}
.startvex-width-77 {
    width: 77% !important;
}
.startvex-width-78 {
    width: 78% !important;
}
.startvex-width-79 {
    width: 79% !important;
}
.startvex-width-80 {
    width: 80% !important;
}
.startvex-width-81 {
    width: 81% !important;
}
.startvex-width-82 {
    width: 82% !important;
}
.startvex-width-83 {
    width: 83% !important;
}
.startvex-width-84 {
    width: 84% !important;
}
.startvex-width-85 {
    width: 85% !important;
}
.startvex-width-86 {
    width: 86% !important;
}
.startvex-width-87 {
    width: 87% !important;
}
.startvex-width-88 {
    width: 88% !important;
}
.startvex-width-89 {
    width: 89% !important;
}
.startvex-width-90 {
    width: 90% !important;
}
.startvex-width-91 {
    width: 91% !important;
}
.startvex-width-92 {
    width: 92% !important;
}
.startvex-width-93 {
    width: 93% !important;
}
.startvex-width-94 {
    width: 94% !important;
}
.startvex-width-95 {
    width: 95% !important;
}
.startvex-width-96 {
    width: 96% !important;
}
.startvex-width-97 {
    width: 97% !important;
}
.startvex-width-98 {
    width: 98% !important;
}
.startvex-width-99 {
    width: 99% !important;
}
.startvex-width-100 {
    width: 100% !important;
}


/* Company onboarding - pricing layout */
:root {
    --bg-deck: #0b1220;
    /* fundo externo */
    --bg-card: #0f1726;
    /* fundo do card */
    --border-default: #243043;
    /* borda padrão dos botões */
    --text-primary: #e6e9ef;
    /* título */
    --text-muted: #97a3b6;
    /* subtítulo */
    --accent: #12d4bb;
    /* verde/água do destaque */
    --accent-ghost: rgba(18, 212, 187, .12);
    /* glow sutil */
    --badge-bg: #0d2d2c;
    /* fundo do selo "Recomendado" */
}

.payment-wrapper {
    background: var(--bg-deck);
    border-radius: 14px;
    padding: 18px;
}

.payment-card {
    background: var(--bg-card);
    border-radius: 14px;
    padding: 18px;
}

.pay-option {
    display: block;
    border: 1px solid var(--border-default);
    border-radius: 12px;
    padding: 18px;
    text-decoration: none;
    background: transparent;
    transition: box-shadow .2s, border-color .2s, transform .05s;
}

.pay-option:hover {
    transform: translateY(-1px);
    box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.02);
}

.pay-option h6 {
    margin: 0;
    color: var(--text-primary);
    font-weight: 600;
}

.pay-option p {
    margin: 4px 0 0 0;
    color: var(--text-muted);
    font-size: .95rem;
}

.pay-option.active {
    border-color: var(--accent);
    box-shadow: 0 0 0 2px var(--accent-ghost);
}

.badge-reco {
    font-size: .75rem;
    line-height: 1;
    padding: .35rem .5rem;
    background: var(--badge-bg);
    color: var(--accent);
    border: 1px solid var(--accent);
    border-radius: 999px;
    margin-left: .5rem;
}

/* Authentication access */
.access-highlight {
    background: linear-gradient(140deg, #0f172a 0%, #1f2937 100%);
    color: #fff;
}

.access-highlight .border-white-10 {
    border-color: rgba(255, 255, 255, 0.1) !important;
}

.access-highlight .text-soft {
    color: rgba(255, 255, 255, 0.72) !important;
}

.access-toggle .btn {
    min-width: 120px;
}

.access-toggle .btn.active {
    color: #fff;
}

.access-toggle .btn:not(.active) {
    background-color: transparent;
}

.access-toggle .btn.btn-outline-primary:hover,
.access-toggle .btn.btn-outline-primary:focus,
.access-toggle .btn.btn-outline-primary:active {
    color: #0f172a;
    background-color: #ffffff;
    border-color: #0d6efd;
}

/* Invest overview */
.invest-user-card {
    background: linear-gradient(135deg, #312e81 0%, #1d4ed8 100%);
    border: none;
    color: #fff;
    position: relative;
    overflow: hidden;
}

.invest-user-card::after {
    content: "";
    position: absolute;
    inset: -40% 40% 40% -40%;
    background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.18) 0%, transparent 62%);
    pointer-events: none;
}

.invest-user-card .avatar {
    border: 3px solid rgba(255, 255, 255, 0.35);
    box-shadow: 0 10px 25px rgba(15, 23, 42, 0.35);
}

.invest-user-card .user-meta span {
    display: block;
}

.invest-user-card .metric-value {
    font-size: 26px;
    font-weight: 600;
    color: #fff;
}

.invest-user-card .badge-soft {
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
}

.invest-user-card .card-body,
.invest-user-card .card-body h1,
.invest-user-card .card-body h2,
.invest-user-card .card-body h3,
.invest-user-card .card-body h4,
.invest-user-card .card-body h5,
.invest-user-card .card-body h6,
.invest-user-card .card-body p,
.invest-user-card .card-body span,
.invest-user-card .card-body small {
    color: #fff;
}

.invest-user-card .card-body .text-white-50 {
    color: rgba(255, 255, 255, 0.65) !important;
}

.invest-user-card .card-body .text-white-75 {
    color: rgba(255, 255, 255, 0.75) !important;
}

.invest-smartcompany-card {
    border: 1px solid #eef2ff;
    border-radius: 16px;
    transition: box-shadow 0.25s ease, transform 0.25s ease;
}

.invest-smartcompany-link {
    display: block;
    text-decoration: none;
    color: inherit;
}

.invest-smartcompany-link:hover {
    text-decoration: none;
    color: inherit;
}

.invest-smartcompany-card:hover {
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.12);
    transform: translateY(-2px);
}

.invest-smartcompany-card .avatar {
    background: #eff6ff;
    border-radius: 14px;
}

.invest-smartcompany-card .token-badge {
    background-color: rgba(59, 130, 246, 0.12);
    color: #2563eb;
    font-weight: 500;
}

.invest-smartcompany-empty .empty-state-title {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}

.invest-smartcompany-empty .empty-state-icon {
    font-size: 28px;
    line-height: 1;
}

.portfolio-kpi-card {
    border-radius: 14px;
    border: 1px solid #f1f5f9;
    padding: 16px;
}

#investments-trend {
    min-height: 340px;
}

.exchange-rate-item {
    border-radius: 14px;
    border: 1px solid #eef2ff;
    padding: 16px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.exchange-rate-item:hover {
    border-color: rgba(99, 102, 241, 0.35);
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08);
}

.exchange-rate-item .avatar {
    border-radius: 14px;
    background: #f8fafc;
}

.rate-change.positive {
    color: #16a34a;
}

.rate-change.negative {
    color: #ef4444;
}

.invest-holdings-table .avatar {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    background: #f8fafc;
    overflow: hidden;
}

.invest-holdings-table .avatar img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.invest-holdings-table .company-name {
    display: block;
    font-weight: 600;
    color: var(--default-text-color);
}

[data-theme-mode="dark"] .invest-holdings-table .company-name {
    color: #f8fafc;
}

.invest-holdings-table td {
    vertical-align: middle;
}

.invest-statement-modal .table td,
.invest-statement-modal .table th {
    vertical-align: middle;
}

@media (max-width: 575.98px) {
    .invest-user-card .metric-value {
        font-size: 22px;
    }
}

/* Launchpad detail */
.launchpad-wrapper {
    --lp-radius: 0.5rem;
    --lp-hero-height: 280px;
    display: flex;
    flex-direction: column;
    margin-top: 1.5rem;
}

.launchpad-top-row {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.launchpad-wrapper .nft-banner-card {
    border: 1px solid var(--default-border);
    border-radius: var(--lp-radius);
    background: var(--custom-white);
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.08);
}

.launchpad-wrapper .nft-banner-card .card-body {
    background: transparent;
}

.launchpad-callout {
    position: relative;
    border-radius: var(--lp-radius);
    overflow: hidden;
    background: var(--custom-white);
    border: 1px solid var(--default-border);
    color: var(--default-text-color);
    min-height: var(--lp-hero-height);
    height: 100%;
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.08);
}

.launchpad-callout::before {
    content: "";
    position: absolute;
    inset: -40% 40% auto -20%;
    width: 480px;
    max-width: 80%;
    aspect-ratio: 1;
    background: radial-gradient(circle, rgba(var(--primary-rgb), 0.12), transparent 72%);
    pointer-events: none;
}

.launchpad-callout__body {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 1.75rem;
    padding: 2.4rem;
    height: 100%;
}

.launchpad-callout__text {
    max-width: 420px;
}

.launchpad-callout__title {
    font-size: 2.05rem;
    font-weight: 600;
    color: var(--default-text-color);
    margin-bottom: 1rem;
}

.launchpad-callout__description {
    color: var(--text-muted);
    font-size: 1rem;
    line-height: 1.55;
    margin-bottom: 1.5rem;
}

.launchpad-callout__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.launchpad-callout__actions .btn {
    border-radius: 999px;
    padding: 0.55rem 1.4rem;
    font-weight: 600;
}

.launchpad-callout__illustration {
    align-self: flex-end;
    background: var(--default-background);
    border-radius: 50%;
    padding: 1rem;
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.12);
}

.launchpad-callout__illustration img {
    display: block;
    width: 140px;
    height: 140px;
    object-fit: cover;
    border-radius: 50%;
}

.launchpad-partner {
    border: 1px solid var(--default-border);
    border-radius: var(--lp-radius) !important;
    background: var(--custom-white);
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.08);
    padding: 1.75rem;
    min-height: var(--lp-hero-height);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.launchpad-partner__body {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 1.5rem;
    height: 100%;
}

.launchpad-partner__body h6 {
    font-weight: 600;
    color: var(--default-text-color);
    margin-bottom: 0.75rem;
}

.launchpad-partner__body p {
    color: var(--text-muted);
    margin-bottom: 0;
}

.launchpad-partner__amount span {
    font-size: 0.8rem;
    color: #64748b;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.launchpad-partner__amount h4 {
    margin: 0.4rem 0 0;
    font-weight: 600;
    color: var(--primary-color);
}

.launchpad-partner__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.launchpad-partner__actions .btn {
    border-radius: 999px;
    padding: 0.55rem 1.35rem;
    font-weight: 600;
}

.launchpad-metric-card {
    border: 1px solid var(--default-border);
    border-radius: var(--lp-radius) !important;
    background: var(--custom-white);
    padding: 1.3rem;
    display: flex;
    gap: 1rem;
    align-items: center;
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.08);
    height: 100%;
}

.launchpad-metric-icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(var(--primary-rgb), 0.12);
    color: var(--primary-color);
    font-size: 1.4rem;
}

.launchpad-metric-card h6 {
    margin: 0;
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--default-text-color);
}

.launchpad-metric-card span {
    display: block;
    margin-top: 0.2rem;
    color: var(--text-muted);
    font-size: 0.85rem;
}

.launchpad-section.card {
    border: 1px solid var(--default-border);
    border-radius: var(--lp-radius) !important;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
    background: var(--custom-white);
}

.launchpad-section .card-body {
    padding: 2rem;
}

.launchpad-section__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.launchpad-section__header h5 {
    margin: 0;
    font-weight: 600;
    color: var(--default-text-color);
}

.launchpad-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin: 0 0 1.5rem;
}

.launchpad-filter-btn {
    border: 1px solid var(--default-border);
    background: var(--custom-white);
    color: var(--default-text-color);
    padding: 0.45rem 1.15rem;
    border-radius: 999px;
    font-size: 0.85rem;
    font-weight: 500;
    transition: all 0.2s ease;
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.04);
}

.launchpad-filter-btn:hover {
    border-color: rgba(var(--primary-rgb), 0.5);
    color: var(--primary-color);
    box-shadow: 0 10px 22px rgba(59, 130, 246, 0.15);
}

.launchpad-filter-btn.active {
    background: var(--primary-color);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 12px 30px rgba(37, 99, 235, 0.28);
}

.launchpad-carousel {
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
    gap: 1rem;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 0.5rem;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}

.launchpad-carousel::-webkit-scrollbar {
    height: 6px;
}

.launchpad-carousel::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.4);
    border-radius: 999px;
}

.company-card {
    border: 1px solid var(--default-border);
    border-radius: var(--lp-radius) !important;
    padding: 1.3rem;
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    background: var(--custom-white);
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.08);
    flex: 0 0 280px;
    min-height: 100%;
    scroll-snap-align: start;
}

.company-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.14);
}

.company-card__header {
    display: flex;
    align-items: center;
    gap: 0.9rem;
}

.company-card__logo {
    width: 56px;
    height: 56px;
    border-radius: 0.75rem;
    background: var(--default-background);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px;
}

.company-card__logo img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.company-card__body {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.company-card__bottom {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.company-card__stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    font-size: 0.85rem;
    color: var(--text-muted);
}

.company-card__progress {
    height: 8px;
    background: rgba(148, 163, 184, 0.25);
    border-radius: 999px;
    overflow: hidden;
}

.company-card__progress span {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, #2563eb, #38bdf8);
    border-radius: inherit;
}

.company-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.company-card__footer .btn[disabled] {
    pointer-events: none;
    opacity: 0.65;
    cursor: not-allowed;
}

[data-theme-mode="dark"] .launchpad-callout {
    background: rgba(var(--body-bg-rgb), 0.95);
    border-color: rgba(255, 255, 255, 0.08);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.62);
}

[data-theme-mode="dark"] .launchpad-callout__title {
    color: #f8fafc;
}

[data-theme-mode="dark"] .launchpad-callout__description {
    color: rgba(226, 232, 240, 0.74);
}

[data-theme-mode="dark"] .launchpad-callout__illustration {
    background: rgba(var(--body-bg-rgb2), 0.45);
    box-shadow: 0 16px 36px rgba(0, 0, 0, 0.55);
}

[data-theme-mode="dark"] .launchpad-wrapper .nft-banner-card {
    background: rgba(var(--body-bg-rgb), 0.94);
    border-color: rgba(255, 255, 255, 0.08);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.55);
}

[data-theme-mode="dark"] .launchpad-wrapper .nft-banner-card .text-fixed-white {
    color: #f8fafc !important;
}

[data-theme-mode="dark"] .launchpad-partner,
[data-theme-mode="dark"] .launchpad-metric-card,
[data-theme-mode="dark"] .launchpad-section.card,
[data-theme-mode="dark"] .company-card,
[data-theme-mode="dark"] .company-table__row {
    background: rgba(var(--body-bg-rgb), 0.93);
    border-color: rgba(255, 255, 255, 0.08);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.55);
}

[data-theme-mode="dark"] .launchpad-partner__body h6,
[data-theme-mode="dark"] .launchpad-metric-card h6,
[data-theme-mode="dark"] .launchpad-section__header h5,
[data-theme-mode="dark"] .company-card h6,
[data-theme-mode="dark"] .company-table__meta h6 {
    color: #f8fafc;
}

[data-theme-mode="dark"] .launchpad-partner__body p,
[data-theme-mode="dark"] .launchpad-metric-card span,
[data-theme-mode="dark"] .company-card p,
[data-theme-mode="dark"] .company-card__stats,
[data-theme-mode="dark"] .company-table__meta p,
[data-theme-mode="dark"] .company-table__pitch {
    color: rgba(203, 213, 225, 0.78);
}

[data-theme-mode="dark"] .launchpad-metric-icon {
    background: rgba(var(--primary-rgb), 0.22);
    color: #93c5fd;
}

[data-theme-mode="dark"] .launchpad-section .badge {
    background: rgba(var(--primary-rgb), 0.18) !important;
    color: #bfdbfe !important;
}

[data-theme-mode="dark"] .company-card__stats strong {
    color: #f8fafc;
}

[data-theme-mode="dark"] .company-card__progress,
[data-theme-mode="dark"] .company-table__progress .progress {
    background: rgba(148, 163, 184, 0.28);
}

[data-theme-mode="dark"] .company-card__footer span {
    color: rgba(203, 213, 225, 0.78);
}

[data-theme-mode="dark"] .launchpad-filter-btn {
    background: rgba(var(--body-bg-rgb), 0.92);
    border-color: rgba(255, 255, 255, 0.08);
    color: #f8fafc;
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.5);
}

[data-theme-mode="dark"] .launchpad-filter-btn:hover {
    border-color: rgba(var(--primary-rgb), 0.6);
    color: #bfdbfe;
}

[data-theme-mode="dark"] .launchpad-filter-btn.active {
    background: rgba(var(--primary-rgb), 0.9);
    box-shadow: 0 12px 32px rgba(37, 99, 235, 0.45);
}

[data-theme-mode="dark"] .company-card__logo,
[data-theme-mode="dark"] .company-table__meta img {
    background: rgba(var(--body-bg-rgb2), 0.6);
}

[data-theme-mode="dark"] .company-empty {
    background: rgba(var(--body-bg-rgb), 0.9);
    border-color: rgba(255, 255, 255, 0.12);
    color: rgba(226, 232, 240, 0.78);
}

.company-table {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.company-table__row {
    border: 1px solid var(--default-border);
    border-radius: var(--lp-radius) !important;
    padding: 1.2rem;
    display: grid;
    grid-template-columns: 1.3fr 1fr 1fr 1fr 0.8fr;
    gap: 1rem;
    align-items: center;
    background: var(--custom-white);
    box-shadow: 0 6px 18px rgba(15, 23, 42, 0.05);
}

.company-table__meta {
    display: flex;
    gap: 0.85rem;
    align-items: center;
}

.company-table__meta img {
    width: 52px;
    height: 52px;
    border-radius: 0.75rem;
    object-fit: contain;
    background: var(--default-background);
    padding: 8px;
}

.company-table__meta h6 {
    margin: 0;
    font-weight: 600;
    color: var(--default-text-color);
}

.company-table__meta p {
    margin: 0.2rem 0 0;
    color: var(--text-muted);
    font-size: 0.85rem;
}

.company-table__pitch {
    color: var(--text-muted);
    font-size: 0.85rem;
}

.company-table__progress {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.company-table__progress .progress {
    height: 8px;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.28);
}

.company-table__progress .progress-bar {
    background: linear-gradient(90deg, #2563eb, #38bdf8);
    border-radius: inherit;
}

.company-empty {
    text-align: center;
    padding: 2rem;
    border: 1px dashed var(--default-border);
    border-radius: var(--lp-radius) !important;
    color: var(--text-muted);
    background: var(--custom-white);
}

@media (max-width: 1199.98px) {
    .company-table__row {
        grid-template-columns: 1fr;
    }

    .company-table__footer {
        justify-content: flex-start;
    }
}

@media (max-width: 767.98px) {
    .launchpad-callout__body {
        padding: 1.75rem;
    }

    .launchpad-callout__actions {
        width: 100%;
    }

    .launchpad-callout__actions .btn {
        flex: 1 1 auto;
    }

    .launchpad-callout__illustration {
        align-self: center;
        margin: 0 auto;
    }

    .launchpad-callout__illustration img {
        width: 110px;
        height: 110px;
    }

    .launchpad-metric-card {
        flex-direction: row;
    }

    .company-card__stats {
        grid-template-columns: 1fr;
    }
}

/* Whitepage company profile */
.lp-wrapper {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.lp-hero-card {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--default-border);
    border-radius: 0.5rem;
    background: var(--custom-white);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
}

.lp-hero-card::after {
    content: "";
    position: absolute;
    inset: -65% 50% auto -35%;
    height: 100%;
    background: radial-gradient(circle at top left, rgba(var(--primary-rgb), 0.12), transparent 68%);
    pointer-events: none;
}

.lp-hero-body {
    position: relative;
    z-index: 1;
}

.lp-brand-avatar {
    width: 88px;
    height: 88px;
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 12px 32px rgba(15, 23, 42, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px;
}

.lp-brand-avatar img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.lp-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}

.lp-badges .badge {
    font-size: 0.75rem;
    padding: 0.4rem 0.85rem;
    border-radius: 999px;
}

.lp-actions {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.lp-primary-action {
    min-width: 180px;
    border-radius: 999px;
    font-weight: 600;
}

.lp-stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1rem;
    margin: 1.75rem 0 1.25rem;
}

.lp-stat-tile {
    background: rgba(15, 23, 42, 0.035);
    border-radius: 16px;
    padding: 1.1rem;
}

.lp-stat-tile span {
    display: block;
    font-size: 0.775rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #64748b;
}

.lp-stat-tile h4 {
    margin: 0.55rem 0 0;
    font-size: 1.35rem;
    font-weight: 600;
    color: #0f172a;
}

.lp-progress {
    margin-top: 1rem;
}

.lp-progress .progress {
    height: 10px;
    border-radius: 999px;
    background-color: rgba(148, 163, 184, 0.25);
    overflow: visible;
}

.lp-progress .progress-bar {
    background: linear-gradient(90deg, #2563eb, #38bdf8);
    border-radius: 999px;
    position: relative;
}

.lp-progress .progress-bar::after {
    content: attr(data-value);
    position: absolute;
    top: -34px;
    right: -12px;
    background: #0f172a;
    color: #ffffff;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 600;
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.25);
}

.lp-progress-meta {
    margin-top: 0.75rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.5rem;
    color: #475569;
    font-size: 0.85rem;
}

.lp-section-card {
    border-radius: 0.5rem;
    border: 1px solid var(--default-border);
    background: var(--custom-white);
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.08);
}

.lp-section-card .card-body {
    padding: 1.9rem;
}

.lp-section-card h5 {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--default-text-color);
    margin-bottom: 1.05rem;
}

.lp-highlight-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.lp-highlight-list li {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
}

.lp-highlight-icon {
    width: 32px;
    height: 32px;
    border-radius: 12px;
    background: rgba(59, 130, 246, 0.12);
    color: #2563eb;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 1rem;
}

.lp-sticky-card {
    position: sticky;
    top: 88px;
}

.lp-meta-grid {
    display: grid;
    gap: 0.85rem;
}

.lp-meta-item {
    padding: 0.85rem 1rem;
    border-radius: 0.5rem;
    border: 1px solid var(--default-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--custom-white);
}

.lp-meta-item span {
    color: var(--text-muted);
    font-size: 0.85rem;
}

.lp-meta-item strong {
    font-size: 1rem;
    color: var(--default-text-color);
}

.lp-other-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1.25rem;
}

.lp-other-card {
    border-radius: 0.5rem;
    border: 1px solid var(--default-border);
    background: var(--custom-white);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1.35rem;
    color: inherit;
    text-decoration: none;
    box-shadow: 0 6px 18px rgba(15, 23, 42, 0.06);
}

.lp-other-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 32px rgba(15, 23, 42, 0.12);
    color: inherit;
    text-decoration: none;
}

.lp-other-card img {
    width: 56px;
    height: 56px;
    border-radius: 0.75rem;
    object-fit: contain;
    background: var(--default-background);
    padding: 6px;
}

.lp-other-card h6 {
    font-size: 1rem;
    color: var(--default-text-color);
}

.lp-empty-state {
    padding: 1.75rem;
    text-align: center;
    border: 1px dashed var(--default-border);
    border-radius: 0.5rem;
    color: var(--text-muted);
    background: var(--custom-white);
}

[data-theme-mode="dark"] .lp-hero-card {
    background: linear-gradient(
        145deg,
        rgba(var(--body-bg-rgb), 0.92) 0%,
        rgba(var(--body-bg-rgb2), 0.98) 100%
    );
    box-shadow: 0 18px 45px -24px rgba(0, 0, 0, 0.55);
    border: 1px solid var(--default-border);
}

[data-theme-mode="dark"] .lp-hero-card::after {
    background: radial-gradient(circle at top left, rgba(var(--primary-rgb), 0.25), transparent 70%);
}

[data-theme-mode="dark"] .lp-hero-card .text-dark,
[data-theme-mode="dark"] .lp-hero-card h2,
[data-theme-mode="dark"] .lp-hero-card h4 {
    color: #e2e8f0 !important;
}

[data-theme-mode="dark"] .lp-stat-tile {
    background: rgba(var(--body-bg-rgb2), 0.82);
    border: 1px solid var(--default-border);
}

[data-theme-mode="dark"] .lp-stat-tile span {
    color: rgba(203, 213, 225, 0.8);
}

[data-theme-mode="dark"] .lp-stat-tile h4 {
    color: #f8fafc;
}

[data-theme-mode="dark"] .lp-progress .progress {
    background-color: rgba(var(--body-bg-rgb2), 0.55);
}

[data-theme-mode="dark"] .lp-progress .progress-bar::after {
    background: #111827;
    color: #f8fafc;
}

[data-theme-mode="dark"] .lp-section-card {
    background: rgba(var(--body-bg-rgb), 0.94);
    border: 1px solid var(--default-border);
    box-shadow: 0 18px 45px -24px rgba(0, 0, 0, 0.5);
}

[data-theme-mode="dark"] .lp-section-card h5 {
    color: #f8fafc;
}

[data-theme-mode="dark"] .lp-section-card .text-dark,
[data-theme-mode="dark"] .lp-section-card strong {
    color: #e2e8f0 !important;
}

[data-theme-mode="dark"] .lp-section-card .text-muted {
    color: rgba(203, 213, 225, 0.75) !important;
}

[data-theme-mode="dark"] .lp-meta-item {
    background: rgba(var(--body-bg-rgb), 0.9);
    border-color: rgba(255, 255, 255, 0.12);
}

[data-theme-mode="dark"] .lp-meta-item span {
    color: rgba(203, 213, 225, 0.78);
}

[data-theme-mode="dark"] .lp-meta-item strong {
    color: #f8fafc;
}

[data-theme-mode="dark"] .lp-section-card .badge.bg-primary-subtle {
    background-color: rgba(var(--primary-rgb), 0.18) !important;
    color: rgba(var(--primary-rgb), 0.85) !important;
}

[data-theme-mode="dark"] .lp-other-card {
    background: rgba(var(--body-bg-rgb), 0.94);
    border-color: var(--default-border);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.38);
}

[data-theme-mode="dark"] .lp-other-card:hover {
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.45);
}

[data-theme-mode="dark"] .lp-other-card h6 {
    color: #e2e8f0;
}

[data-theme-mode="dark"] .lp-other-card img {
    background: rgba(var(--body-bg-rgb2), 0.85);
}

[data-theme-mode="dark"] .lp-empty-state {
    background: rgba(var(--body-bg-rgb), 0.9);
    border-color: var(--default-border);
    color: rgba(226, 232, 240, 0.82);
}

@media (max-width: 767.98px) {
    .lp-wrapper {
        gap: 1.5rem;
    }

    .lp-actions {
        width: 100%;
    }

    .lp-actions .btn {
        width: 100%;
    }

    .lp-sticky-card {
        position: static;
    }

.lp-section-card .card-body {
        padding: 1.5rem;
    }
}

/* Tokenomics */
.tokenomics-card .tokenomics-progress {
    height: 12px;
    background-color: rgba(148, 163, 184, 0.25);
    border-radius: 999px;
    overflow: hidden;
}

.tokenomics-card .progress-bar {
    border-radius: 999px;
}

.tokenomics-summary .form-text {
    font-size: 0.75rem;
}

.tokenomics-dot {
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 999px;
    margin-right: 8px;
    background-color: var(--tokenomics-color, #6366f1);
    box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.08);
    vertical-align: middle;
}

.tokenomics-chip {
    border: 1px solid var(--tokenomics-color, #6366f1);
    background-color: transparent;
    color: var(--tokenomics-color, #6366f1);
    font-weight: 500;
    line-height: 1.2;
}

.tokenomics-token {
    font-size: 1rem;
}

.tokenomics-range-note {
    margin-top: 4px;
}

.tokenomics-tip {
    background-color: rgba(37, 99, 235, 0.08);
    border: 1px dashed rgba(148, 163, 184, 0.55);
}

.tokenomics-chart {
    height: 260px;
}

.tokenomics-chart #tokenomics-chart {
    height: 100%;
}

.tokenomics-chart-token {
    height: 280px;
}

.tokenomics-chart-token #whitepage-tokenomics-chart {
    height: 100%;
}

.tokenomics-chart .apexcharts-datalabel-label,
.tokenomics-chart .apexcharts-datalabel-value,
.tokenomics-chart .apexcharts-datalabel-label text,
.tokenomics-chart .apexcharts-datalabel-value text,
.tokenomics-chart-token .apexcharts-datalabel-label,
.tokenomics-chart-token .apexcharts-datalabel-value,
.tokenomics-chart-token .apexcharts-datalabel-label text,
.tokenomics-chart-token .apexcharts-datalabel-value text {
    fill: var(--default-text-color, #1e293b) !important;
    color: var(--default-text-color, #1e293b) !important;
}

.tokenomics-input-group .form-control[readonly] {
    background-color: rgba(226, 232, 240, 0.45);
    cursor: not-allowed;
}

[data-theme-mode="dark"] .tokenomics-tip {
    background-color: rgba(37, 99, 235, 0.16);
    border-color: rgba(148, 163, 184, 0.4);
}

[data-theme-mode="dark"] .tokenomics-input-group .form-control[readonly] {
    background-color: rgba(148, 163, 184, 0.2);
    color: rgba(226, 232, 240, 0.92);
    border-color: rgba(148, 163, 184, 0.35);
}

.tokenomics-total-value {
    color: var(--default-text-color, #1e293b);
}

[data-theme-mode="dark"] .tokenomics-total-value {
    color: #f8fafc;
}

/* Investment test demo */
.startvex-invest-demo {
    font-family: Arial, sans-serif;
    padding: 20px;
    background-color: #f4f4f4;
}

.startvex-invest-demo label {
    margin-top: 10px;
    font-weight: bold;
    display: block;
}

.startvex-invest-demo input,
.startvex-invest-demo button {
    padding: 10px;
    margin-top: 5px;
    font-size: 16px;
}

.startvex-invest-demo button {
    background-color: #28a745;
    color: #ffffff;
    border: none;
    cursor: pointer;
}

.startvex-invest-demo button:hover {
    background-color: #218838;
}

.startvex-invest-demo #result {
    margin-top: 20px;
    font-weight: bold;
}
