html {
  font-size: 14px;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

html {
  position: relative;
  min-height: 100%;
}

body {
  margin-bottom: 60px;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
  color: var(--bs-secondary-color);
  text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
  text-align: start;
}

. /*home-hero {
    min-height: calc(100vh - 120px);
    background-image: url('/img/club-bg.jpg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}*/
.home-hero {
    min-height: 420px;
    background: linear-gradient(135deg, #f8f9fa, #e9ecef);
}

.home-hero .card {
    transition: transform .2s ease, box-shadow .2s ease;
}

    .home-hero .card:hover {
        transform: translateY(-4px);
        box-shadow: 0 .75rem 1.5rem rgba(0,0,0,.08);
    }

.home-modern {
    min-height: calc(100vh - 140px);
    background: radial-gradient(circle at top left, rgba(13, 110, 253, 0.10), transparent 30%), radial-gradient(circle at bottom right, rgba(25, 135, 84, 0.08), transparent 30%), linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%);
}

.hero-panel {
    background: rgba(255, 255, 255, 0.72);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,.55);
    border-radius: 24px;
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.08);
    padding: 2rem;
}

.hero-badge {
    display: inline-block;
    padding: .45rem .85rem;
    border-radius: 999px;
    background: #e9f2ff;
    color: #0d6efd;
    font-size: .85rem;
    font-weight: 600;
    margin-bottom: 1rem;
}

.hero-title {
    font-size: clamp(1.8rem, 3vw, 3rem);
    font-weight: 700;
    color: #0f172a;
    margin-bottom: .75rem;
}

.hero-subtitle {
    color: #475569;
    font-size: 1.05rem;
    max-width: 760px;
    margin-bottom: 1.5rem;
}

.module-card {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    height: 100%;
    padding: 1.35rem;
    border-radius: 22px;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    border: 1px solid rgba(15, 23, 42, 0.06);
}

    .module-card:hover {
        transform: translateY(-6px);
        box-shadow: 0 18px 38px rgba(15, 23, 42, 0.12);
    }

.module-card-primary {
    background: linear-gradient(135deg, #0d6efd 0%, #3b82f6 100%);
    color: #fff;
}

.module-card-outline {
    background: #fff;
    color: #0f172a;
}

.module-card-dark {
    background: linear-gradient(135deg, #111827 0%, #1f2937 100%);
    color: #fff;
}

.module-icon {
    width: 58px;
    height: 58px;
    min-width: 58px;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    background: rgba(255,255,255,.18);
}

.module-card-outline .module-icon {
    background: #eff6ff;
    color: #0d6efd;
}

.module-body h5 {
    font-size: 1.15rem;
    font-weight: 700;
    margin-bottom: .45rem;
}

.module-body p {
    margin-bottom: .9rem;
    opacity: .88;
    line-height: 1.5;
}

.module-link {
    font-weight: 600;
    font-size: .95rem;
}

.module-card-primary .module-link,
.module-card-dark .module-link {
    color: #fff;
}

.module-card-outline .module-link {
    color: #0d6efd;
}

@media (max-width: 768px) {
    .hero-panel {
        padding: 1.25rem;
        border-radius: 18px;
    }

    .module-card {
        border-radius: 18px;
    }
}
/* ===== Links de cadastro (RegistrationLinks/Index) ===== */

.rl-page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    margin-bottom: 1rem;
}

.rl-title {
    display: flex;
    align-items: baseline;
    gap: .75rem;
    flex-wrap: wrap;
    margin: 0;
}

.rl-subtle {
    color: rgba(0,0,0,.55);
    font-size: .95rem;
}

.rl-hint {
    font-size: .85rem;
    color: rgba(0,0,0,.6);
}

.rl-filters .form-label {
    font-size: .85rem;
    color: rgba(0,0,0,.65);
    margin-bottom: .35rem;
}

.rl-badge {
    font-weight: 600;
    padding: .35rem .55rem;
    border-radius: 999px;
    font-size: .78rem;
    display: inline-block;
    line-height: 1.1;
}

.rl-badge-success {
    background: rgba(25,135,84,.12);
    color: #198754;
}

.rl-badge-danger {
    background: rgba(220,53,69,.12);
    color: #dc3545;
}

.rl-badge-secondary {
    background: rgba(108,117,125,.15);
    color: #6c757d;
}

/* Desktop table: no scroll interno, layout fixo pra truncar link */
.rl-table {
    table-layout: fixed;
    width: 100%;
}

.rl-td, .rl-th {
    vertical-align: middle;
}

.rl-link {
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    font-size: .9rem;
}

/* Dropdown actions button */
.rl-icon-btn {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    padding: 0;
    line-height: 1;
}

/* Dropdown menu appearance */
.rl-dd-menu {
    min-width: 220px;
    border-radius: 12px;
    box-shadow: 0 14px 40px rgba(0,0,0,.12);
}

/* Mobile cards */
.rl-card {
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 14px;
    padding: 1rem;
    background: #fff;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
}

    .rl-card + .rl-card {
        margin-top: .75rem;
    }

.rl-kv {
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: .25rem .75rem;
    align-items: start;
    font-size: .95rem;
    margin-top: .5rem;
}

.rl-k {
    color: rgba(0,0,0,.6);
    font-size: .85rem;
}
/* ===== Financeiro ===== */

.fin-valor-receita {
    color: #198754; /* verde bootstrap success */
    font-weight: 600;
}

.fin-valor-despesa {
    color: #dc3545; /* vermelho bootstrap danger */
    font-weight: 600;
}

.fin-saldo-positivo {
    color: #198754;
    font-weight: 700;
}

.fin-saldo-negativo {
    color: #dc3545;
    font-weight: 700;
}

.fin-saldo-zero {
    color: #6c757d;
    font-weight: 600;
}
/* ===== Backoffice Assinaturas ===== */

.ba-page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.ba-page-subtitle {
    color: rgba(0, 0, 0, .58);
    margin: 0;
}

.ba-stat-card {
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.06);
    height: 100%;
}

    .ba-stat-card .card-body {
        padding: 1rem 1.1rem;
    }

.ba-stat-label {
    font-size: .82rem;
    color: rgba(0, 0, 0, .55);
    margin-bottom: .35rem;
}

.ba-stat-value {
    font-size: 1.55rem;
    font-weight: 700;
    line-height: 1.1;
    color: #0f172a;
}

.ba-stat-value-money {
    font-size: 1.2rem;
}

.ba-filter-card,
.ba-table-card {
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.06);
}

    .ba-filter-card .card-body,
    .ba-table-card .card-body {
        padding: 1.25rem;
    }

.ba-filter-label {
    font-size: .88rem;
    font-weight: 600;
    color: #334155;
    margin-bottom: .45rem;
}

.ba-table {
    width: 100%;
    margin-bottom: 0;
    vertical-align: middle;
}

    .ba-table thead th {
        font-size: .78rem;
        text-transform: uppercase;
        letter-spacing: .04em;
        color: rgba(0, 0, 0, .58);
        white-space: nowrap;
        border-bottom: 1px solid rgba(0, 0, 0, .08);
        padding-top: .95rem;
        padding-bottom: .95rem;
    }

    .ba-table tbody td {
        padding-top: 1rem;
        padding-bottom: 1rem;
        vertical-align: middle;
    }

    .ba-table tbody tr:hover {
        background: rgba(13, 110, 253, .02);
    }

.ba-club-name {
    font-weight: 600;
    color: #111827;
    line-height: 1.2;
}

.ba-club-slug,
.ba-subtle-text {
    font-size: .83rem;
    color: rgba(0, 0, 0, .56);
}

.ba-plan-wrap {
    display: flex;
    flex-direction: column;
    gap: .1rem;
}

.ba-plan-name {
    font-weight: 600;
    color: #111827;
}

.ba-status-wrap {
    display: flex;
    flex-direction: column;
    gap: .35rem;
}

.ba-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: .38rem .72rem;
    font-size: .78rem;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
}

.ba-pill-success {
    background: rgba(25, 135, 84, .12);
    color: #198754;
}

.ba-pill-warning {
    background: rgba(255, 193, 7, .18);
    color: #8a6d00;
}

.ba-pill-danger {
    background: rgba(220, 53, 69, .12);
    color: #dc3545;
}

.ba-pill-secondary {
    background: rgba(108, 117, 125, .14);
    color: #6c757d;
}

.ba-days {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    padding: .35rem .7rem;
    border-radius: 999px;
    font-size: .82rem;
    font-weight: 700;
    background: #eef2f7;
    color: #334155;
}

.ba-days-warning {
    background: rgba(255, 193, 7, .18);
    color: #8a6d00;
}

.ba-days-danger {
    background: rgba(220, 53, 69, .12);
    color: #dc3545;
}

.ba-actions-cell {
    width: 1%;
    white-space: nowrap;
}

.ba-action-btn {
    border-radius: 999px;
    padding-left: .9rem;
    padding-right: .9rem;
}

.ba-dd-menu {
    min-width: 220px;
    border: 1px solid rgba(0, 0, 0, .06);
    border-radius: 14px;
    padding: .45rem;
    box-shadow: 0 14px 40px rgba(0, 0, 0, .12);
}

.ba-dd-item {
    border-radius: 10px;
    padding: .6rem .75rem;
    font-size: .92rem;
}

.ba-dd-form {
    margin: 0;
}

    .ba-dd-form .dropdown-item {
        width: 100%;
        text-align: left;
        border: 0;
        background: transparent;
    }

.ba-plan-panel {
    margin-top: .75rem;
    padding: 1rem;
    border-radius: 14px;
    border: 1px solid rgba(0, 0, 0, .08);
    background: #f8fafc;
}

.ba-empty {
    padding: 3rem 1rem;
    text-align: center;
    color: rgba(0, 0, 0, .56);
}

.ba-alert {
    border: 0;
    border-radius: 14px;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
}

@media (max-width: 991.98px) {
    .ba-page-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .ba-filter-actions {
        width: 100%;
    }

        .ba-filter-actions .btn {
            flex: 1 1 auto;
        }
}

/* ===== Backoffice Histórico de Cobranças ===== */

.bhc-page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.bhc-page-subtitle {
    color: rgba(0, 0, 0, .58);
    margin: 0;
}

.bhc-card {
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.06);
}

    .bhc-card .card-body {
        padding: 1.25rem;
    }

.bhc-table {
    width: 100%;
    margin-bottom: 0;
    vertical-align: middle;
}

    .bhc-table thead th {
        font-size: .78rem;
        text-transform: uppercase;
        letter-spacing: .04em;
        color: rgba(0, 0, 0, .58);
        white-space: nowrap;
        border-bottom: 1px solid rgba(0, 0, 0, .08);
        padding-top: .95rem;
        padding-bottom: .95rem;
    }

    .bhc-table tbody td {
        padding-top: 1rem;
        padding-bottom: 1rem;
        vertical-align: middle;
    }

    .bhc-table tbody tr:hover {
        background: rgba(13, 110, 253, .02);
    }

.bhc-txid,
.bhc-subtle {
    font-size: .83rem;
    color: rgba(0, 0, 0, .56);
}

.bhc-main-text {
    color: #111827;
    font-weight: 600;
    line-height: 1.2;
}

.bhc-payer {
    display: flex;
    flex-direction: column;
    gap: .2rem;
}

.bhc-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: .38rem .72rem;
    font-size: .78rem;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
}

.bhc-pill-success {
    background: rgba(25, 135, 84, .12);
    color: #198754;
}

.bhc-pill-warning {
    background: rgba(255, 193, 7, .18);
    color: #8a6d00;
}

.bhc-pill-danger {
    background: rgba(220, 53, 69, .12);
    color: #dc3545;
}

.bhc-pill-secondary {
    background: rgba(108, 117, 125, .14);
    color: #6c757d;
}

.bhc-empty {
    padding: 3rem 1rem;
    text-align: center;
    color: rgba(0, 0, 0, .56);
}

.bhc-back-btn {
    border-radius: 999px;
    padding-left: 1rem;
    padding-right: 1rem;
}

.bhc-detail-box {
    max-width: 340px;
    white-space: normal;
    word-break: break-word;
}

@media (max-width: 991.98px) {
    .bhc-page-header {
        flex-direction: column;
        align-items: flex-start;
    }
}
/* ===== Assinaturas - Pagamento Pix ===== */

.spp-page {
    background: radial-gradient(circle at top left, rgba(13, 110, 253, 0.08), transparent 32%), radial-gradient(circle at top right, rgba(25, 135, 84, 0.06), transparent 26%), #f8fafc;
    min-height: calc(100vh - 80px);
}

.spp-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.spp-eyebrow {
    display: inline-block;
    margin-bottom: .5rem;
    padding: .35rem .75rem;
    border-radius: 999px;
    background: rgba(13, 110, 253, 0.12);
    color: #0d6efd;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.spp-title {
    font-weight: 800;
    color: #0f172a;
}

.spp-subtitle,
.spp-muted {
    color: #64748b;
}

.spp-card {
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.08);
}

.spp-alert {
    border: 0;
    border-radius: 16px;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.spp-label {
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: #64748b;
}

.spp-value-lg {
    font-size: 1.5rem;
    font-weight: 800;
    color: #0f172a;
    line-height: 1.15;
}

.spp-value {
    font-size: 1.15rem;
    font-weight: 700;
    color: #0f172a;
}

.spp-price {
    font-size: 1.8rem;
    font-weight: 800;
    color: #0f172a;
    line-height: 1.1;
}

.spp-plan-box {
    border: 1px solid rgba(13, 110, 253, 0.12);
    background: linear-gradient(180deg, rgba(13, 110, 253, 0.04), rgba(13, 110, 253, 0.02));
    border-radius: 18px;
    padding: 1rem 1.1rem;
}

.spp-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: .45rem .85rem;
    border-radius: 999px;
    font-size: .85rem;
    font-weight: 700;
    line-height: 1;
}

.spp-status-warning {
    background: rgba(255, 193, 7, 0.16);
    color: #8a6d00;
}

.spp-status-success {
    background: rgba(25, 135, 84, 0.14);
    color: #198754;
}

.spp-qr-card {
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 18px;
    padding: 1rem;
    background: #fff;
}

.spp-qr-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 280px;
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.8), rgba(255, 255, 255, 1));
    border: 1px dashed rgba(100, 116, 139, 0.28);
}

.spp-copy-box {
    display: flex;
    flex-direction: column;
    gap: .85rem;
}

.spp-textarea {
    border-radius: 16px;
    resize: none;
    font-size: .92rem;
    line-height: 1.45;
    padding: 1rem;
    background: #f8fafc;
    border-color: rgba(100, 116, 139, 0.22);
}

.spp-copy-btn {
    align-self: flex-start;
    border-radius: 999px;
    padding-left: 1rem;
    padding-right: 1rem;
}

.spp-info-card {
    height: 100%;
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 16px;
    background: #fff;
    padding: .95rem 1rem;
}

.spp-info-value {
    margin-top: .35rem;
    font-weight: 700;
    color: #0f172a;
}

.spp-dev-box {
    border: 1px dashed rgba(255, 193, 7, 0.5);
    background: rgba(255, 193, 7, 0.08);
    border-radius: 16px;
    padding: 1rem;
}

.spp-side-section + .spp-side-section {
    margin-top: 1.25rem;
}

.spp-list {
    margin-top: .9rem;
    padding-left: 1.15rem;
    color: #334155;
}

    .spp-list li + li {
        margin-top: .45rem;
    }

.spp-status-panel {
    margin-top: .9rem;
    padding: 1rem 1.1rem;
    border-radius: 18px;
    border: 1px solid transparent;
}

.spp-status-panel-warning {
    background: rgba(255, 193, 7, 0.12);
    border-color: rgba(255, 193, 7, 0.25);
}

.spp-status-panel-success {
    background: rgba(25, 135, 84, 0.10);
    border-color: rgba(25, 135, 84, 0.24);
}

.spp-status-panel-title {
    font-weight: 800;
    color: #0f172a;
    margin-bottom: .4rem;
}

.spp-status-panel-text {
    color: #475569;
}

.spp-summary-grid {
    display: grid;
    gap: .75rem;
    margin-top: .9rem;
}

.spp-summary-item {
    display: flex;
    flex-direction: column;
    gap: .18rem;
    padding: .8rem .9rem;
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 14px;
    background: #fff;
}

.spp-summary-key {
    font-size: .76rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #64748b;
}

.spp-summary-value {
    color: #0f172a;
    font-weight: 600;
    word-break: break-word;
}

.spp-footer-note {
    text-align: center;
}

@media (max-width: 991.98px) {
    .spp-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .spp-copy-btn {
        width: 100%;
    }
}

/* ===== Assinaturas - Checkout Público ===== */

.spc-page {
    background: radial-gradient(circle at top left, rgba(13, 110, 253, 0.08), transparent 32%), radial-gradient(circle at bottom right, rgba(25, 135, 84, 0.06), transparent 26%), #f8fafc;
    min-height: calc(100vh - 80px);
}

.spc-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.spc-eyebrow {
    display: inline-block;
    margin-bottom: .5rem;
    padding: .35rem .75rem;
    border-radius: 999px;
    background: rgba(13, 110, 253, 0.12);
    color: #0d6efd;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.spc-title {
    font-weight: 800;
    color: #0f172a;
}

.spc-subtitle,
.spc-muted {
    color: #64748b;
}

.spc-card {
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.08);
}

.spc-alert {
    border: 0;
    border-radius: 16px;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.spc-label {
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: #64748b;
}

.spc-value-lg {
    font-size: 1.55rem;
    font-weight: 800;
    color: #0f172a;
    line-height: 1.15;
}

.spc-status-box {
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 18px;
    background: #fff;
    padding: 1rem 1.1rem;
}

.spc-status-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: .45rem .85rem;
    border-radius: 999px;
    font-size: .85rem;
    font-weight: 700;
    line-height: 1;
}

.spc-status-active {
    background: rgba(25, 135, 84, 0.14);
    color: #198754;
}

.spc-status-warning {
    background: rgba(255, 193, 7, 0.16);
    color: #8a6d00;
}

.spc-status-danger {
    background: rgba(220, 53, 69, 0.12);
    color: #dc3545;
}

.spc-plan-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.spc-plan-card {
    position: relative;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 22px;
    background: #fff;
    padding: 1.1rem;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
    cursor: pointer;
    height: 100%;
}

    .spc-plan-card:hover {
        transform: translateY(-4px);
        box-shadow: 0 16px 36px rgba(15, 23, 42, 0.10);
        border-color: rgba(13, 110, 253, 0.22);
    }

    .spc-plan-card.is-selected {
        border-color: rgba(13, 110, 253, 0.42);
        box-shadow: 0 18px 40px rgba(13, 110, 253, 0.10);
        background: linear-gradient(180deg, rgba(13, 110, 253, 0.03), rgba(13, 110, 253, 0.01));
    }

    .spc-plan-card.is-recommended {
        border-color: rgba(13, 110, 253, 0.28);
    }

.spc-plan-radio {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.spc-plan-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: .32rem .7rem;
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .03em;
    text-transform: uppercase;
    background: rgba(13, 110, 253, 0.12);
    color: #0d6efd;
    margin-bottom: .8rem;
}

.spc-plan-title {
    font-size: 1.2rem;
    font-weight: 800;
    color: #0f172a;
    margin-bottom: .35rem;
}

.spc-plan-price {
    font-size: 2rem;
    font-weight: 800;
    line-height: 1;
    color: #0f172a;
    margin-bottom: .4rem;
}

.spc-plan-period {
    color: #64748b;
    font-size: .92rem;
    margin-bottom: .9rem;
}

.spc-plan-desc {
    color: #475569;
    font-size: .94rem;
    min-height: 44px;
    margin-bottom: 1rem;
}

.spc-plan-features {
    list-style: none;
    padding: 0;
    margin: 0;
}

    .spc-plan-features li {
        display: flex;
        align-items: flex-start;
        gap: .55rem;
        color: #334155;
        font-size: .93rem;
    }

        .spc-plan-features li + li {
            margin-top: .55rem;
        }

        .spc-plan-features li::before {
            content: "✓";
            color: #198754;
            font-weight: 800;
            line-height: 1.2;
        }

.spc-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.spc-field-full {
    grid-column: 1 / -1;
}

.spc-submit-box {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    margin-top: 1.25rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.spc-submit-note {
    color: #64748b;
    font-size: .92rem;
    max-width: 560px;
}

.spc-summary-list {
    display: grid;
    gap: .75rem;
}

.spc-summary-item {
    display: flex;
    flex-direction: column;
    gap: .18rem;
    padding: .85rem .95rem;
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 14px;
    background: #fff;
}

.spc-summary-key {
    font-size: .76rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #64748b;
}

.spc-summary-value {
    color: #0f172a;
    font-weight: 600;
    word-break: break-word;
}

.spc-side-box {
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 18px;
    padding: 1rem 1.1rem;
    background: #fff;
}

    .spc-side-box + .spc-side-box {
        margin-top: 1rem;
    }

.spc-check-list {
    margin: .85rem 0 0;
    padding-left: 1.1rem;
    color: #334155;
}

    .spc-check-list li + li {
        margin-top: .45rem;
    }

.spc-validation .validation-summary-errors ul,
.spc-validation .validation-summary-valid ul {
    margin-bottom: 0;
}

@media (max-width: 991.98px) {
    .spc-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .spc-plan-grid {
        grid-template-columns: 1fr;
    }

    .spc-form-grid {
        grid-template-columns: 1fr;
    }

    .spc-submit-box .btn {
        width: 100%;
    }
}
.global-loading {
    position: fixed;
    inset: 0;
    z-index: 99999;
}

    .global-loading.d-none {
        display: none !important;
    }

.global-loading__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
}

.global-loading__content {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}