:root {
    --agive-bg: #f1ebde;
    --agive-surface: #ffffff;
    --agive-surface-soft: #faf7f1;
    --agive-primary: #213e60;
    --agive-primary-hover: #1a314d;
    --agive-secondary: #e7dcc7;
    --agive-text: #1f2a37;
    --agive-text-soft: #667085;
    --agive-border: #e9e3d7;
    --agive-success: #2e9b62;
    --agive-warning: #d48a24;
    --agive-danger: #d9534f;
    --agive-radius-lg: 24px;
    --agive-radius-md: 18px;
    --agive-radius-sm: 12px;
    --agive-shadow: 0 12px 40px rgba(33, 62, 96, 0.08);
    --agive-shadow-soft: 0 8px 24px rgba(31, 42, 55, 0.06);
}

* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    padding: 0;
}

body.agive-theme {
    font-family: 'Inter', Arial, sans-serif;
    background: var(--agive-bg);
    color: var(--agive-text);
    line-height: 1.5;
}

a {
    color: inherit;
    text-decoration: none;
}

img {
    max-width: 100%;
    display: block;
}

.agive-layout {
    min-height: 100vh;
    display: flex;
}

.agive-sidebar {
    width: 280px;
    background: var(--agive-primary);
    color: #fff;
    padding: 28px 20px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: sticky;
    top: 0;
    height: 100vh;
    z-index: 1000;
}

.agive-sidebar__brand img {
    max-width: 170px;
    margin: 0 auto 24px;
}

.agive-sidebar__nav {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.agive-nav-link {
    display: flex;
    align-items: center;
    padding: 14px 16px;
    border-radius: 14px;
    color: rgba(255,255,255,0.92);
    transition: 0.2s ease;
    font-weight: 500;
}

.agive-nav-link:hover {
    background: rgba(255,255,255,0.10);
    color: #fff;
}

.agive-sidebar__footer {
    margin-top: 24px;
}

.agive-user-box {
    display: flex;
    gap: 12px;
    align-items: center;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 18px;
    padding: 14px;
    margin-bottom: 16px;
}

.agive-user-box__avatar {
    width: 42px;
    height: 42px;
    border-radius: 999px;
    background: #fff;
    color: var(--agive-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
}

.agive-user-box__info {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.agive-user-box__info strong,
.agive-user-box__info span {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.agive-user-box__info span {
    color: rgba(255,255,255,0.75);
    font-size: 13px;
}

.agive-main {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.agive-topbar {
    margin: 20px 20px 0;
    background: var(--agive-surface);
    border: 1px solid var(--agive-border);
    border-radius: var(--agive-radius-lg);
    box-shadow: var(--agive-shadow-soft);
    padding: 18px 22px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.agive-topbar__left {
    display: flex;
    align-items: center;
    gap: 16px;
}

.agive-page-title {
    margin: 0;
    font-size: 24px;
    font-weight: 800;
    color: var(--agive-primary);
}

.agive-page-subtitle {
    margin: 4px 0 0;
    color: var(--agive-text-soft);
    font-size: 14px;
}

.agive-topbar-link {
    color: var(--agive-primary);
    font-weight: 600;
}

.agive-content {
    padding: 20px;
}

.agive-footer {
    padding: 0 20px 20px;
}

.agive-footer__inner {
    background: var(--agive-surface);
    border: 1px solid var(--agive-border);
    border-radius: var(--agive-radius-lg);
    padding: 18px 22px;
    color: var(--agive-text-soft);
    font-size: 14px;
}

.agive-menu-toggle {
    width: 46px;
    height: 46px;
    border: 0;
    border-radius: 14px;
    background: var(--agive-surface-soft);
    cursor: pointer;
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 4px;
    padding: 0 12px;
}

.agive-menu-toggle span {
    display: block;
    height: 2px;
    width: 100%;
    background: var(--agive-primary);
    border-radius: 999px;
}

.agive-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.45);
    opacity: 0;
    visibility: hidden;
    transition: 0.25s ease;
    z-index: 999;
}

.agive-overlay.active {
    opacity: 1;
    visibility: visible;
}

.agive-badge {
    display: inline-flex;
    align-items: center;
    padding: 8px 12px;
    border-radius: 999px;
    background: var(--agive-secondary);
    color: var(--agive-primary);
    font-size: 13px;
    font-weight: 700;
}

.agive-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 18px;
    border-radius: 14px;
    font-weight: 700;
    transition: 0.2s ease;
    border: 1px solid transparent;
    cursor: pointer;
}

.agive-btn--primary {
    background: var(--agive-primary);
    color: #fff;
}

.agive-btn--primary:hover {
    background: var(--agive-primary-hover);
}

.agive-btn--secondary {
    background: var(--agive-secondary);
    color: var(--agive-primary);
}

.agive-btn--secondary:hover {
    filter: brightness(0.98);
}

.agive-btn--ghost {
    background: transparent;
    color: #fff;
    border-color: rgba(255,255,255,0.16);
}

.agive-btn--full {
    width: 100%;
}

.agive-card__header h3 {
    margin: 0 0 6px;
    color: var(--agive-primary);
    font-size: 20px;
}

.agive-card__header p {
    margin: 0 0 20px;
    color: var(--agive-text-soft);
}

.agive-inline-link {
    color: var(--agive-primary);
    font-weight: 700;
}

.agive-form {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.agive-form-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.agive-form-group label {
    font-size: 14px;
    font-weight: 700;
    color: var(--agive-primary);
}

.agive-form-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.agive-form-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.agive-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--agive-text-soft);
    font-size: 14px;
}

.agive-auth-layout {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    box-sizing: border-box;
}

.agive-auth-page {
    width: 100%;
    max-width: 1080px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 18px;
}

.agive-auth {
    width: 100%;
}

.agive-auth__wrapper {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    align-items: center;
}

.agive-auth__brand,
.agive-auth__card {
    background: var(--agive-surface);
    border: 1px solid var(--agive-border);
    border-radius: 28px;
    box-shadow: var(--agive-shadow);
    padding: 34px;
    box-sizing: border-box;
    width: 100%;
}

.agive-auth__brand {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-self: center;
}

.agive-auth__brand h2 {
    margin: 12px 0;
    font-size: 40px;
    line-height: 1.08;
    color: var(--agive-primary);
}

.agive-auth__brand p {
    margin: 0;
    color: var(--agive-text-soft);
    font-size: 16px;
    line-height: 1.65;
    max-width: 520px;
}

.agive-auth__brand-logo {
    margin-bottom: 18px;
}

.agive-auth__brand-logo img {
    max-height: 56px;
    width: auto;
}

.agive-auth__card {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.agive-auth__footer {
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid var(--agive-border);
}

.agive-auth__footer p {
    margin: 0 0 12px;
    color: var(--agive-text-soft);
}

.agive-auth-page .agive-footer {
    padding: 0;
}

.agive-auth-page .agive-footer__inner {
    margin-left: auto;
    max-width: 280px;
    padding: 18px 22px;
    border-radius: 22px;
}

.agive-auth__wrapper > *,
.agive-auth-page .agive-footer,
.agive-auth-page .agive-footer__inner {
    box-sizing: border-box;
}

/* Melhorando elementos nativos do WHMCS */
.panel,
.tile,
.client-home-panels .panel,
.card,
.domain-renewal-mode,
.product-status,
.alert,
.table-container,
form .form-control,
form .form-select,
form select,
form input[type="text"],
form input[type="email"],
form input[type="password"],
form input[type="tel"],
form textarea {
    border-radius: 16px !important;
}

.panel,
.tile,
.client-home-panels .panel,
.card,
.alert,
.table-container {
    border: 1px solid var(--agive-border) !important;
    box-shadow: var(--agive-shadow-soft) !important;
}

.btn-primary,
.btn.btn-primary,
input.btn-primary {
    background: var(--agive-primary) !important;
    border-color: var(--agive-primary) !important;
    border-radius: 14px !important;
}

.btn-primary:hover,
.btn.btn-primary:hover,
input.btn-primary:hover {
    background: var(--agive-primary-hover) !important;
    border-color: var(--agive-primary-hover) !important;
}

.btn-default,
.btn.btn-default,
.btn-secondary {
    border-radius: 14px !important;
}

.form-control,
.form-select,
select,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
textarea {
    width: 100%;
    min-height: 46px;
    border: 1px solid var(--agive-border) !important;
    box-shadow: none !important;
    padding: 10px 14px !important;
    background: #fff;
}

.alert-success {
    background: rgba(46, 155, 98, 0.10) !important;
    color: var(--agive-success) !important;
    border-color: rgba(46, 155, 98, 0.22) !important;
}

.alert-warning {
    background: rgba(212, 138, 36, 0.10) !important;
    color: var(--agive-warning) !important;
    border-color: rgba(212, 138, 36, 0.22) !important;
}

.alert-danger,
.alert-error {
    background: rgba(217, 83, 79, 0.10) !important;
    color: var(--agive-danger) !important;
    border-color: rgba(217, 83, 79, 0.22) !important;
}

/* Footer padrão */
.agive-footer {
    padding: 0 20px 20px;
}

/* Footer da tela de login */
.agive-footer--auth {
    padding: 0;
}

.agive-footer__inner {
    background: var(--agive-surface);
    border: 1px solid var(--agive-border);
    border-radius: 22px;
    padding: 18px 22px;
    color: var(--agive-text-soft);
    font-size: 14px;
}

/* Desktop - canto direito */
.agive-auth-page .agive-footer__inner {
    margin-left: auto;
    max-width: 280px;
}

/* Mobile - largura total */
@media (max-width: 991px) {
    .agive-auth-page .agive-footer__inner {
        margin-left: 0;
        max-width: 100%;
        width: 100%;
    }
}

.agive-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.agive-checkbox--block {
    align-items: flex-start;
    line-height: 1.5;
}

.agive-checkbox--block input {
    margin-top: 3px;
}

.agive-reset-text {
    margin: 12px 0 0;
    color: var(--agive-text-soft);
    line-height: 1.6;
}

.agive-reset-text {
    margin: 12px 0 0;
    color: var(--agive-text-soft);
    line-height: 1.6;
}

.agive-auth__card form {
    margin-top: 8px;
}

.agive-auth__card .btn,
.agive-auth__card button,
.agive-auth__card input[type="submit"] {
    font-family: 'Inter', Arial, sans-serif;
}

.agive-auth__card button.agive-btn,
.agive-auth__card .agive-btn {
    appearance: none;
    -webkit-appearance: none;
    border: 0;
}

.agive-auth__card .alert {
    margin-bottom: 16px;
}

.agive-auth__card p {
    color: var(--agive-text-soft);
}

.agive-auth__card label {
    color: var(--agive-primary);
    font-weight: 700;
}

.agive-auth__card .form-control {
    width: 100%;
}

.agive-form-section {
    margin-top: 16px;
}

.agive-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.agive-checkbox--block {
    display: flex;
    gap: 8px;
    margin-top: 12px;
    font-size: 14px;
}

.agive-form-section-title {
    margin: 8px 0 18px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.agive-form-section-title span {
    font-size: 18px;
    font-weight: 800;
    color: var(--agive-primary);
}

.agive-form-section-title small {
    color: var(--agive-text-soft);
    font-size: 13px;
}

.agive-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.agive-form-grid--address {
    grid-template-columns: 1.2fr 1fr 0.8fr;
}

.agive-form-section {
    margin-top: 16px;
}

.agive-field-help-text {
    display: block;
    margin-top: 6px;
    font-size: 13px;
    color: var(--agive-text-soft);
}

.agive-password-help {
    margin: 10px 0 0;
    font-size: 13px;
    color: var(--agive-text-soft);
}

.agive-marketing-optin {
    margin-top: 18px;
    padding: 18px;
    border: 1px solid var(--agive-border);
    border-radius: 18px;
    background: var(--agive-surface-soft);
}

.agive-marketing-optin h4 {
    margin: 0 0 8px;
    color: var(--agive-primary);
}

.agive-marketing-optin p {
    margin: 0 0 12px;
    color: var(--agive-text-soft);
}

.agive-tos-box {
    margin-top: 18px;
    padding: 18px;
    border: 1px solid rgba(217, 83, 79, 0.22);
    border-radius: 18px;
    background: rgba(217, 83, 79, 0.06);
}

.agive-tos-box h4 {
    margin: 0 0 10px;
    color: var(--agive-danger);
}

#frmCheckout .hidden {
    display: none !important;
}

#frmCheckout .progress {
    height: 10px;
    border-radius: 999px;
    overflow: hidden;
    background: #e9ecef;
}

#frmCheckout .progress-bar {
    height: 100%;
}

#frmCheckout .field,
#frmCheckout input[type="text"],
#frmCheckout input[type="email"],
#frmCheckout input[type="password"],
#frmCheckout input[type="tel"],
#frmCheckout select {
    width: 100%;
}

.agive-dashboard {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.agive-hero {
    background: linear-gradient(135deg, #ffffff 0%, #faf7f1 100%);
    border: 1px solid var(--agive-border);
    border-radius: 28px;
    box-shadow: var(--agive-shadow);
    padding: 32px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

.agive-hero h2 {
    margin: 10px 0 12px;
    font-size: 34px;
    line-height: 1.1;
    color: var(--agive-primary);
}

.agive-hero p {
    margin: 0;
    max-width: 680px;
    color: var(--agive-text-soft);
    font-size: 16px;
}

.agive-hero__actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.agive-stats-grid,
.agive-grid {
    display: grid;
    gap: 20px;
}

.agive-stats-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.agive-grid--2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.agive-grid--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.agive-stat-card,
.agive-card {
    background: var(--agive-surface);
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
}

.agive-stat-card {
    padding: 22px;
    display: block;
    transition: 0.2s ease;
}

.agive-stat-card:hover {
    transform: translateY(-2px);
}

.agive-stat-card__label {
    color: var(--agive-text-soft);
    font-size: 14px;
    margin-bottom: 8px;
}

.agive-stat-card__value {
    font-size: 24px;
    font-weight: 800;
    color: var(--agive-primary);
    margin-bottom: 12px;
}

.agive-stat-card__link {
    color: var(--agive-primary);
    font-weight: 700;
}

.agive-card {
    padding: 24px;
}

.agive-card--soft {
    background: var(--agive-surface-soft);
}

.agive-shortcuts {
    display: grid;
    gap: 14px;
}

.agive-shortcut {
    padding: 18px;
    border: 1px solid var(--agive-border);
    border-radius: 18px;
    background: #fff;
    transition: 0.2s ease;
}

.agive-shortcut:hover {
    transform: translateY(-2px);
    box-shadow: var(--agive-shadow-soft);
}

.agive-shortcut strong {
    display: block;
    color: var(--agive-primary);
    margin-bottom: 6px;
}

.agive-shortcut span {
    display: block;
    color: var(--agive-text-soft);
    font-size: 14px;
}

.agive-support-box p {
    color: var(--agive-text-soft);
    margin: 0 0 16px;
}

.agive-support-box__actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.agive-list {
    display: grid;
    gap: 14px;
}

.agive-list-item {
    padding: 16px 18px;
    border: 1px solid var(--agive-border);
    border-radius: 18px;
    background: #fff;
}

.agive-list-item strong {
    display: block;
    color: var(--agive-primary);
    margin-bottom: 6px;
}

.agive-list-item span {
    color: var(--agive-text-soft);
    font-size: 14px;
}

.agive-page-section {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.agive-page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.agive-page-header h2 {
    margin: 0 0 6px;
    color: var(--agive-primary);
    font-size: 28px;
    font-weight: 800;
}

.agive-page-header p {
    margin: 0;
    color: var(--agive-text-soft);
}

.agive-table-card {
    background: var(--agive-surface);
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
    overflow: hidden;
}

.agive-table-wrap {
    width: 100%;
    overflow-x: auto;
}

.agive-table {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
}

.agive-table thead th {
    font-size: 14px;
    font-weight: 700;
    color: var(--agive-primary);
    background: var(--agive-surface-soft);
    padding: 16px 18px;
    text-align: left;
    border-bottom: 1px solid var(--agive-border);
    white-space: nowrap;
}

.agive-table td {
    padding: 16px 18px;
    border-bottom: 1px solid var(--agive-border);
    vertical-align: middle;
}

.agive-table tbody tr:last-child td {
    border-bottom: 0;
}

.agive-table tbody tr:hover {
    background: rgba(33, 62, 96, 0.03);
}

.agive-table-subtext {
    display: block;
    margin-top: 4px;
    font-size: 13px;
    color: var(--agive-text-soft);
}

.agive-empty-state {
    background: var(--agive-surface);
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
    padding: 42px 24px;
    text-align: center;
}

.agive-empty-state h3 {
    margin: 0 0 10px;
    color: var(--agive-primary);
    font-size: 24px;
}

.agive-empty-state p {
    margin: 0 0 20px;
    color: var(--agive-text-soft);
}

.agive-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px 12px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 700;
    white-space: nowrap;
}

.agive-status--active,
.agive-status--paid,
.agive-status--open,
.agive-status--completed {
    background: rgba(46, 155, 98, 0.12);
    color: var(--agive-success);
}

.agive-status--pending,
.agive-status--paymentpending,
.agive-status--pendingtransfer {
    background: rgba(212, 138, 36, 0.12);
    color: var(--agive-warning);
}

.agive-status--cancelled,
.agive-status--closed,
.agive-status--fraud,
.agive-status--unpaid,
.agive-status--expired,
.agive-status--terminated {
    background: rgba(217, 83, 79, 0.12);
    color: var(--agive-danger);
}

.agive-btn--sm {
    min-height: 38px;
    padding: 0 14px;
    border-radius: 12px;
    font-size: 14px;
}

.agive-info-list {
    display: grid;
    gap: 14px;
}

.agive-info-list__item {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 0;
    border-bottom: 1px solid var(--agive-border);
}

.agive-info-list__item:last-child {
    border-bottom: 0;
}

.agive-info-list__item span {
    color: var(--agive-text-soft);
}

.agive-info-list__item strong {
    color: var(--agive-primary);
    text-align: right;
}

.agive-actions-vertical {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.agive-muted {
    color: var(--agive-text-soft);
}

.text-right {
    text-align: right;
}

.agive-ticket-thread {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.agive-ticket-message {
    border: 1px solid var(--agive-border);
    border-radius: 20px;
    padding: 18px;
    background: #fff;
    box-shadow: var(--agive-shadow-soft);
}

.agive-ticket-message--staff {
    border-left: 4px solid var(--agive-primary);
    background: #fcfbf8;
}

.agive-ticket-message--client {
    border-left: 4px solid var(--agive-secondary);
}

.agive-ticket-message__meta {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.agive-ticket-message__meta strong {
    display: block;
    color: var(--agive-primary);
}

.agive-ticket-message__meta span {
    display: block;
    color: var(--agive-text-soft);
    font-size: 13px;
    margin-top: 4px;
}

.agive-ticket-message__body {
    color: var(--agive-text);
    line-height: 1.65;
    word-break: break-word;
}

.agive-ticket-message__body img {
    max-width: 100%;
    height: auto;
}

.agive-ticket-role {
    font-size: 12px;
    font-weight: 700;
    color: var(--agive-text-soft);
    margin-left: 6px;
}

.agive-ticket-attachments {
    margin-top: 14px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.agive-homepage {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.agive-public-hero {
    background: linear-gradient(135deg, #ffffff 0%, #faf7f1 100%);
    border: 1px solid var(--agive-border);
    border-radius: 28px;
    box-shadow: var(--agive-shadow);
    padding: 36px;
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 24px;
    align-items: center;
}

.agive-public-hero__content h1 {
    margin: 12px 0;
    font-size: 40px;
    line-height: 1.08;
    color: var(--agive-primary);
    max-width: 720px;
}

.agive-public-hero__content p {
    margin: 0;
    color: var(--agive-text-soft);
    font-size: 16px;
    line-height: 1.7;
    max-width: 680px;
}

.agive-public-hero__actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 22px;
}

.agive-public-hero__card {
    display: grid;
    gap: 14px;
}

.agive-public-mini-card {
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid var(--agive-border);
    border-radius: 20px;
    padding: 18px;
    box-shadow: var(--agive-shadow-soft);
}

.agive-public-mini-card strong {
    display: block;
    margin-bottom: 6px;
    color: var(--agive-primary);
}

.agive-public-mini-card span {
    color: var(--agive-text-soft);
    font-size: 14px;
}

.agive-public-grid {
    display: grid;
    gap: 20px;
}

.agive-public-grid--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

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

.agive-public-feature {
    padding: 18px;
    border: 1px solid var(--agive-border);
    border-radius: 18px;
    background: #fff;
}

.agive-public-feature strong {
    display: block;
    margin-bottom: 6px;
    color: var(--agive-primary);
}

.agive-public-feature span {
    color: var(--agive-text-soft);
    font-size: 14px;
    line-height: 1.6;
}

.agive-public-cta {
    background: var(--agive-surface);
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
    padding: 28px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 18px;
    flex-wrap: wrap;
}

.agive-public-cta h3 {
    margin: 0 0 6px;
    color: var(--agive-primary);
    font-size: 24px;
}

.agive-public-cta p {
    margin: 0;
    color: var(--agive-text-soft);
}

.agive-public-cta__actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.agive-form textarea {
    resize: vertical;
    min-height: 140px;
}

.agive-form small {
    display: block;
    margin-top: 6px;
}

.agive-form select.form-control {
    height: 48px;
    border-radius: 14px;
}

.agive-form input[type="file"] {
    padding: 10px;
}

.agive-form-group label {
    font-weight: 600;
    margin-bottom: 6px;
    display: block;
    color: var(--agive-primary);
}

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

.agive-department-card {
    display: block;
    padding: 20px;
    border: 1px solid var(--agive-border);
    border-radius: 20px;
    background: #fff;
    box-shadow: var(--agive-shadow-soft);
    transition: 0.2s ease;
}

.agive-department-card:hover {
    transform: translateY(-2px);
}

.agive-department-card strong {
    display: block;
    margin-bottom: 8px;
    color: var(--agive-primary);
    font-size: 18px;
}

.agive-department-card span {
    color: var(--agive-text-soft);
    font-size: 14px;
    line-height: 1.6;
}

.agive-static-field {
    min-height: 46px;
    display: flex;
    align-items: center;
    padding: 10px 14px;
    border: 1px solid var(--agive-border);
    border-radius: 14px;
    background: #fff;
    color: var(--agive-text);
}

.agive-module-area {
    overflow-x: auto;
}

.agive-module-area .table,
.agive-module-area table {
    width: 100%;
}

.agive-module-area .btn,
.agive-module-area button,
.agive-module-area input[type="submit"],
.agive-module-area a.btn {
    border-radius: 12px !important;
}

.agive-product-tabs {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.agive-tabs-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 0;
    margin: 0;
    list-style: none;
}

.agive-tabs-nav li a {
    display: inline-flex;
    align-items: center;
    padding: 10px 14px;
    border-radius: 999px;
    background: var(--agive-surface-soft);
    color: var(--agive-primary);
    font-weight: 700;
    border: 1px solid var(--agive-border);
}

.agive-tabs-nav li.active a {
    background: var(--agive-primary);
    color: #fff;
    border-color: var(--agive-primary);
}

.agive-product-tabs-content .tab-pane {
    padding-top: 8px;
}

.agive-tab-block {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.agive-empty-inline {
    padding: 18px;
    border: 1px dashed var(--agive-border);
    border-radius: 18px;
    color: var(--agive-text-soft);
    text-align: center;
}

.agive-addon-actions {
    margin-top: 10px;
}

.agive-addon-actions .btn,
.agive-addon-actions a.btn {
    margin-right: 8px;
    margin-bottom: 8px;
}

.agive-module-area {
    overflow-x: auto;
}

.agive-module-area .btn,
.agive-module-area a.btn,
.agive-module-area button,
.agive-module-area input[type="submit"] {
    border-radius: 12px !important;
}

.agive-module-area .table,
.agive-module-area table {
    width: 100%;
}

.agive-module-area a,
.agive-module-area button,
.agive-module-area input[type="button"],
.agive-module-area input[type="submit"],
.agive-module-area .btn,
.agive-addon-actions a,
.agive-addon-actions button,
.agive-addon-actions input[type="button"],
.agive-addon-actions input[type="submit"],
.agive-addon-actions .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0 14px;
    border-radius: 12px !important;
    border: 1px solid var(--agive-primary) !important;
    background: var(--agive-primary) !important;
    color: #fff !important;
    font-weight: 600;
    text-decoration: none !important;
    box-shadow: none !important;
    cursor: pointer;
}

.agive-module-area a:hover,
.agive-module-area button:hover,
.agive-module-area input[type="button"]:hover,
.agive-module-area input[type="submit"]:hover,
.agive-module-area .btn:hover,
.agive-addon-actions a:hover,
.agive-addon-actions button:hover,
.agive-addon-actions input[type="button"]:hover,
.agive-addon-actions input[type="submit"]:hover,
.agive-addon-actions .btn:hover {
    background: var(--agive-primary-hover) !important;
    border-color: var(--agive-primary-hover) !important;
    color: #fff !important;
}

.agive-module-area p a,
.agive-module-area p button,
.agive-module-area p input[type="button"],
.agive-module-area p input[type="submit"] {
    margin-right: 8px;
    margin-bottom: 8px;
}

.agive-module-area .btn-default,
.agive-module-area .btn.btn-default,
.agive-addon-actions .btn-default,
.agive-addon-actions .btn.btn-default {
    background: var(--agive-secondary) !important;
    border-color: var(--agive-secondary) !important;
    color: var(--agive-primary) !important;
}

.agive-module-area .btn-default:hover,
.agive-module-area .btn.btn-default:hover,
.agive-addon-actions .btn-default:hover,
.agive-addon-actions .btn.btn-default:hover {
    filter: brightness(0.98);
}

.agive-product-tabs {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.agive-tabs-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 0;
    margin: 0;
    list-style: none;
}

.agive-tabs-nav li {
    margin: 0;
}

.agive-tabs-nav li a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 16px;
    border-radius: 999px;
    background: var(--agive-surface-soft);
    color: var(--agive-primary);
    font-weight: 700;
    border: 1px solid var(--agive-border);
    text-decoration: none;
}

.agive-tabs-nav li.active a,
.agive-tabs-nav li a:hover {
    background: var(--agive-primary);
    color: #fff;
    border-color: var(--agive-primary);
}

.agive-product-tabs-content {
    width: 100%;
}

.agive-product-tabs-content > .tab-pane {
    display: none;
}

.agive-product-tabs-content > .tab-pane.active {
    display: block;
}

.agive-product-tabs-content > .tab-pane.fade {
    opacity: 1;
}

.agive-product-tabs-content > .tab-pane.fade:not(.active) {
    display: none;
}

.agive-inline-form {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 12px;
}

.agive-inline-form .agive-btn,
.agive-inline-form input[type="submit"],
.agive-inline-form a {
    margin: 0;
}

.agive-sidebar__top {
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.agive-nav-link.is-active {
    background: rgba(255,255,255,0.16);
    color: #fff;
    font-weight: 700;
}

.agive-nav-link.is-active:hover {
    background: rgba(255,255,255,0.16);
}

.agive-footer {
    padding: 0 20px 20px;
}

.agive-footer--auth {
    padding: 0;
}

.agive-footer__inner {
    background: var(--agive-surface);
    border: 1px solid var(--agive-border);
    border-radius: 22px;
    padding: 18px 22px;
    color: var(--agive-text-soft);
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.agive-footer__left p {
    margin: 0;
}

.agive-footer__right {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

.agive-footer__right a {
    color: var(--agive-primary);
    font-weight: 600;
    text-decoration: none;
}

.agive-footer__right a:hover {
    text-decoration: underline;
}

.agive-auth-page .agive-footer__inner {
    margin-left: auto;
    max-width: 360px;
}

.agive-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.agive-pagination__center {
    color: var(--agive-text-soft);
    font-weight: 600;
}

.agive-status--paid {
    background: rgba(46, 155, 98, 0.12);
    color: var(--agive-success);
}

.agive-status--unpaid,
.agive-status--payment-pending {
    background: rgba(212, 138, 36, 0.12);
    color: var(--agive-warning);
}

.agive-status--overdue,
.agive-status--cancelled,
.agive-status--collections,
.agive-status--draft {
    background: rgba(217, 83, 79, 0.12);
    color: var(--agive-danger);
}

.agive-actions-vertical .btn,
.agive-actions-vertical a.btn,
.agive-actions-vertical input[type="submit"],
.agive-actions-vertical button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 18px;
    border-radius: 14px !important;
    border: 1px solid var(--agive-primary) !important;
    background: var(--agive-primary) !important;
    color: #fff !important;
    font-weight: 700;
    text-decoration: none !important;
}

.agive-actions-vertical .btn:hover,
.agive-actions-vertical a.btn:hover,
.agive-actions-vertical input[type="submit"]:hover,
.agive-actions-vertical button:hover {
    background: var(--agive-primary-hover) !important;
    border-color: var(--agive-primary-hover) !important;
    color: #fff !important;
}

.agive-payment-field select,
.agive-payment-field input,
.agive-payment-field textarea {
    width: 100%;
}

.agive-payment-inputs .form-group {
    margin-bottom: 16px;
}

.agive-payment-inputs .control-label {
    display: block;
    margin-bottom: 6px;
    color: var(--agive-primary);
    font-weight: 700;
}

.agive-payment-inputs .form-control,
.agive-payment-inputs input[type="text"],
.agive-payment-inputs input[type="tel"],
.agive-payment-inputs input[type="password"],
.agive-payment-inputs select {
    width: 100%;
    min-height: 46px;
    border: 1px solid var(--agive-border) !important;
    border-radius: 14px !important;
    padding: 10px 14px !important;
    box-shadow: none !important;
}

.agive-invoice-summary {
    width: 100%;
}

.agive-invoice-summary .panel,
.agive-invoice-summary .invoice-summary,
.agive-invoice-summary .well,
.agive-invoice-summary .card {
    border-radius: 18px !important;
    border: 1px solid var(--agive-border) !important;
    box-shadow: none !important;
}

.auth3d-area {
    border: 1px solid var(--agive-border);
    border-radius: 18px;
    background: #fff;
}

.agive-payment-field select,
.agive-payment-field input,
.agive-payment-field textarea {
    width: 100%;
}

.agive-payment-inputs .form-group {
    margin-bottom: 16px;
}

.agive-payment-inputs .control-label,
.agive-payment-inputs label {
    display: block;
    margin-bottom: 6px;
    color: var(--agive-primary);
    font-weight: 700;
}

.agive-payment-inputs .form-control,
.agive-payment-inputs input[type="text"],
.agive-payment-inputs input[type="tel"],
.agive-payment-inputs input[type="password"],
.agive-payment-inputs input[type="email"],
.agive-payment-inputs select {
    width: 100%;
    min-height: 46px;
    border: 1px solid var(--agive-border) !important;
    border-radius: 14px !important;
    padding: 10px 14px !important;
    box-shadow: none !important;
    background: #fff !important;
}

.agive-invoice-summary {
    width: 100%;
}

.agive-invoice-summary .panel,
.agive-invoice-summary .invoice-summary,
.agive-invoice-summary .well,
.agive-invoice-summary .card,
.agive-invoice-summary .box {
    border-radius: 18px !important;
    border: 1px solid var(--agive-border) !important;
    box-shadow: none !important;
    background: #fff !important;
}

.agive-invoice-summary .btn,
.agive-invoice-summary a.btn,
.agive-invoice-summary input[type="submit"],
.agive-invoice-summary button {
    border-radius: 12px !important;
}

.auth3d-area {
    border: 1px solid var(--agive-border);
    border-radius: 18px;
    background: #fff;
}

#frmPayment .gateway-errors {
    margin-bottom: 16px;
}

#btnSubmitContainer .click-text.w-hidden,
.gateway-errors.w-hidden {
    display: none !important;
}

.agive-invoice-summary-box {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 20px;
    padding: 22px;
    box-shadow: var(--agive-shadow-soft);
}

.agive-table--compact thead th,
.agive-table--compact td {
    padding: 12px 10px;
}

.agive-invoice-summary-meta {
    margin-top: 18px;
    padding-top: 14px;
    border-top: 1px solid var(--agive-border);
}

.agive-invoice-summary-meta p {
    margin: 0 0 8px;
    color: var(--agive-text-soft);
}

.agive-invoice-summary-meta p:last-child {
    margin-bottom: 0;
}

.agive-invoice-summary-meta strong {
    color: var(--agive-primary);
}

.text-left {
    text-align: left;
}

.agive-header-left {
    display: flex;
    align-items: center;
    gap: 14px;
}

.agive-logo {
    height: 42px;
    width: auto;
}

.agive-checkout-page .agive-grid--2 {
    align-items: start;
}

.agive-payment-form {
    width: 100%;
}

.agive-payment-switcher {
    width: 100%;
    display: block;
    margin-bottom: 16px;
}

.agive-payment-switcher select,
.agive-payment-switcher .form-control,
.agive-payment-switcher input,
.agive-payment-switcher .gateway-selector {
    width: 100% !important;
    min-height: 46px !important;
    border: 1px solid var(--agive-border) !important;
    border-radius: 14px !important;
    padding: 10px 14px !important;
    background: #fff !important;
    color: var(--agive-primary) !important;
    box-shadow: none !important;
}

.agive-payment-switcher .radio,
.agive-payment-switcher .radio-inline,
.agive-payment-switcher label {
    display: block !important;
    margin: 0 0 10px !important;
    color: var(--agive-primary) !important;
    font-weight: 600 !important;
}

.agive-payment-switcher input[type="radio"] {
    width: auto !important;
    min-height: auto !important;
    margin-right: 8px !important;
    padding: 0 !important;
}

.agive-payment-inputs .form-group {
    margin-bottom: 16px;
}

.agive-payment-inputs .control-label,
.agive-payment-inputs label {
    display: block;
    margin-bottom: 6px;
    color: var(--agive-primary);
    font-weight: 700;
}

.agive-payment-inputs .form-control,
.agive-payment-inputs input[type="text"],
.agive-payment-inputs input[type="tel"],
.agive-payment-inputs input[type="password"],
.agive-payment-inputs input[type="email"],
.agive-payment-inputs select {
    width: 100%;
    min-height: 46px;
    border: 1px solid var(--agive-border) !important;
    border-radius: 14px !important;
    padding: 10px 14px !important;
    box-shadow: none !important;
    background: #fff !important;
}

.agive-payment-inputs .help-block,
.agive-payment-inputs .text-muted {
    color: var(--agive-text-soft) !important;
    font-size: 13px;
}

.agive-payment-inputs .has-error .form-control,
.agive-payment-inputs .form-control.input-error {
    border-color: #d9534f !important;
}

.agive-invoice-summary-box {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 20px;
    padding: 22px;
    box-shadow: var(--agive-shadow-soft);
}

.agive-table--compact thead th,
.agive-table--compact td {
    padding: 12px 10px;
}

.agive-invoice-summary-meta {
    margin-top: 18px;
    padding-top: 14px;
    border-top: 1px solid var(--agive-border);
}

.agive-invoice-summary-meta p {
    margin: 0 0 8px;
    color: var(--agive-text-soft);
}

.agive-invoice-summary-meta p:last-child {
    margin-bottom: 0;
}

.agive-invoice-summary-meta strong {
    color: var(--agive-primary);
}

.auth3d-area {
    border: 1px solid var(--agive-border);
    border-radius: 18px;
    background: #fff;
}

#frmPayment .gateway-errors {
    margin-bottom: 16px;
}

#btnSubmitContainer .click-text.w-hidden,
.gateway-errors.w-hidden {
    display: none !important;
}

@media (max-width: 991px) {
    .agive-header-left {
        align-items: flex-start;
    }

    .agive-logo {
        height: 36px;
    }
}

/* ===== Switcher de pagamento para HTML real do WHMCS ===== */

.agive-payment-switcher {
    width: 100%;
}

.agive-payment-switcher .three-column-grid {
    display: grid !important;
    grid-template-columns: 44px 56px minmax(180px, 1fr) 20px 110px;
    align-items: center;
    gap: 0;
    width: 100%;
    background: #fff;
    border: 1px solid #E9E3D7;
    border-radius: 18px;
    overflow: hidden;
    margin-bottom: 16px;
}

.agive-payment-switcher .three-column-grid .paymethod-info {
    display: flex !important;
    align-items: center;
    min-height: 72px;
    padding: 0 16px;
    margin: 0 !important;
    background: transparent;
    border: 0;
}


.agive-payment-switcher .three-column-grid input[type="radio"] {
    width: 18px !important;
    height: 18px !important;
    margin: 0 !important;
    accent-color: #213E60;
    min-height: auto !important;
    padding: 0 !important;
}

.agive-payment-switcher .three-column-grid label {
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    min-height: auto !important;
    width: auto !important;
    color: #213E60;
    font-weight: 700;
    cursor: pointer;
}

.agive-payment-switcher .three-column-grid .paymethod-info:nth-child(2) label {
    display: flex !important;
    align-items: center;
    justify-content: center;
}

.agive-payment-switcher .three-column-grid .paymethod-info:nth-child(2) i {
    font-size: 28px;
    color: #213E60;
    margin: 0;
}

.agive-payment-switcher .three-column-grid .paymethod-info:nth-child(3) label {
    font-size: 16px;
    white-space: nowrap;
}

.agive-payment-switcher .three-column-grid .paymethod-info:nth-child(4) {
    padding: 0;
}

.agive-payment-switcher .three-column-grid .paymethod-info:nth-child(4) label {
    display: none !important;
}

.agive-payment-switcher .three-column-grid .paymethod-info:nth-child(5) label {
    font-size: 15px;
    color: #667085;
    font-weight: 600;
    white-space: nowrap;
}

/* destaque visual do cartão salvo quando selecionado */
.agive-payment-switcher .three-column-grid:has(input[type="radio"]:checked) {
    border-color: #213E60;
    background: rgba(33, 62, 96, 0.04);
    box-shadow: 0 0 0 2px rgba(33, 62, 96, 0.05);
}

/* fallback hover */
.agive-payment-switcher .three-column-grid:hover {
    border-color: #213E60;
}

/* novo cartão */
.agive-payment-switcher > .paymethod-info {
    display: block !important;
    width: 100%;
    margin: 0 !important;
}

.agive-payment-switcher > .paymethod-info label {
    display: flex !important;
    align-items: center;
    gap: 12px;
    min-height: 72px;
    width: 100%;
    padding: 0 18px;
    background: #fff;
    border: 1px solid #E9E3D7 !important;
    border-radius: 18px;
    color: #213E60;
    font-weight: 700;
    cursor: pointer;
    box-sizing: border-box;
}

.agive-payment-switcher > .paymethod-info label:hover {
    border-color: #213E60 !important;
    background: #FAF7F1;
}

.agive-payment-switcher > .paymethod-info input[type="radio"] {
    width: 18px !important;
    height: 18px !important;
    margin: 0 !important;
    accent-color: #213E60;
    min-height: auto !important;
    padding: 0 !important;
}

#newCCInfo {
    margin-right: 2px !important;
}

/* responsivo */
@media (max-width: 767px) {
    .agive-payment-switcher .three-column-grid {
        grid-template-columns: 44px 44px 1fr;
        row-gap: 0;
    }

    .agive-payment-switcher .three-column-grid .paymethod-info:nth-child(4),
    .agive-payment-switcher .three-column-grid .paymethod-info:nth-child(5) {
        grid-column: 3;
        border-left: 1px solid #F1ECE2;
    }

    .agive-payment-switcher .three-column-grid .paymethod-info:nth-child(4) {
        display: none !important;
    }

    .agive-payment-switcher .three-column-grid .paymethod-info:nth-child(5) {
        min-height: 48px;
        padding-top: 0;
    }

    .agive-payment-switcher > .paymethod-info label {
        min-height: 64px;
    }
}

/* novo cartão */
#newCCInfo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    background: #E7DCC7;
    color: #213E60;
    font-weight: 700;
    margin-right: 2px;
}

/* campos do cartão */
.cc-details .form-group,
.agive-payment-inputs .form-group {
    margin-bottom: 18px;
}

.cc-details .control-label,
.agive-payment-inputs .control-label,
.agive-payment-inputs label {
    display: block;
    margin-bottom: 8px;
    font-weight: 700;
    color: #213E60;
}

.cc-details .form-control,
.agive-payment-inputs .form-control,
.agive-payment-inputs input[type="text"],
.agive-payment-inputs input[type="tel"],
.agive-payment-inputs input[type="password"] {
    width: 100%;
    min-height: 48px;
    border-radius: 16px !important;
    border: 1px solid #E9E3D7 !important;
    padding: 12px 14px !important;
    background: #fff !important;
    box-shadow: none !important;
}

/* estrutura bootstrap antiga */
.cc-details .col-sm-4,
.cc-details .col-sm-6,
.cc-details .col-sm-7,
.cc-details .col-sm-8,
.agive-payment-inputs .col-sm-4,
.agive-payment-inputs .col-sm-6,
.agive-payment-inputs .col-sm-7,
.agive-payment-inputs .col-sm-8 {
    width: 100% !important;
    float: none !important;
    padding: 0 !important;
}


/* botão ajuda cvv */
#cvvWhereLink,
.cvv-link,
button.btn.btn-default.btn-sm {
    border: 1px solid #E9E3D7 !important;
    background: #FAF7F1 !important;
    color: #213E60 !important;
    border-radius: 10px !important;
    padding: 6px 10px !important;
    font-size: 12px !important;
    box-shadow: none !important;
}

/* mensagens de erro */
.field-error-msg,
.has-error .help-block,
.agive-payment-inputs .help-block {
    color: #D9534F !important;
    font-size: 13px !important;
    margin-top: 6px !important;
}

.agive-payment-method-group .agive-payment-switcher {
    margin-top: 4px;
}


.hidden {
    display: none !important;
}

/* ===== Checkout premium ===== */

.agive-checkout-page .agive-card__header h3 {
    font-size: 24px;
}

.agive-checkout-page .agive-card__header p {
    font-size: 15px;
}

/* Botão principal */
#btnSubmitContainer {
    margin-top: 22px;
    margin-bottom: 22px;
}

#btnSubmitContainer .agive-btn,
#btnSubmit {
    min-width: 220px;
    min-height: 52px;
    font-size: 16px;
    border-radius: 16px !important;
    box-shadow: 0 10px 24px rgba(33, 62, 96, 0.18);
}

#btnSubmit[disabled] {
    opacity: 0.7;
    cursor: wait;
}

/* Selo de segurança */
.agive-payment-security {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 18px;
    padding: 14px 16px;
    border: 1px solid rgba(212, 138, 36, 0.22);
    background: rgba(212, 138, 36, 0.08);
    color: #b7791f;
    border-radius: 14px;
    font-weight: 600;
}

.agive-payment-security i {
    font-size: 16px;
}

/* Grid dos campos do novo cartão */
.agive-payment-inputs {
    margin-top: 10px;
}

.agive-payment-inputs .form-group {
    margin-bottom: 18px;
}

.agive-payment-inputs .cc-row {
    display: grid;
    grid-template-columns: 1.3fr 0.8fr 0.8fr;
    gap: 14px;
}

.agive-payment-inputs .field-error-msg,
.agive-payment-inputs .help-block {
    display: block;
    margin-top: 6px;
}

/* Botão CVV */
#cvvWhereLink {
    margin-top: 10px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    border-radius: 10px !important;
}

/* Cartão salvo */
.agive-payment-switcher .three-column-grid {
    position: relative;
}

/* Resumo */
.agive-invoice-summary-box {
    position: sticky;
    top: 24px;
}

.agive-invoice-summary-box .agive-card__header h3 {
    font-size: 22px;
}

/* Tabela do resumo mais leve */
.agive-table--compact td,
.agive-table--compact th {
    font-size: 14px;
}

/* Mobile */
@media (max-width: 991px) {
    .agive-payment-inputs .cc-row {
        grid-template-columns: 1fr;
    }

    .agive-invoice-summary-box {
        position: static;
        top: auto;
    }

    #btnSubmitContainer .agive-btn,
    #btnSubmit {
        width: 100%;
        min-width: 0;
    }
}

/* Esconde mensagens de erro e campos de novo cartão por padrão */
.cc-details.hidden,
#inputDescriptionContainer.hidden,
.cc-details.hidden .field-error-msg,
#inputDescriptionContainer.hidden .field-error-msg,
.cc-details.hidden .help-block,
#inputDescriptionContainer.hidden .help-block {
    display: none !important;
}

/* Também esconde o grupo do CVV quando ele estiver marcado como hidden pelo JS */
.form-group.hidden,
.form-group.hidden .field-error-msg,
.form-group.hidden .help-block {
    display: none !important;
}

.alert{
    padding: 10px;
}

/* Esconde mensagens de erro por padrão */
.agive-payment-inputs .field-error-msg,
.agive-payment-inputs .help-block {
    display: none !important;
}

/* Só mostra quando o form estiver validando */
.agive-payment-inputs.is-validating .field-error-msg,
.agive-payment-inputs.is-validating .help-block {
    display: block !important;
}

/* Se o bloco estiver hidden, garante que nada apareça */
.cc-details.hidden,
#inputDescriptionContainer.hidden,
.form-group.hidden {
    display: none !important;
}

.cc-details.hidden .field-error-msg,
#inputDescriptionContainer.hidden .field-error-msg,
.form-group.hidden .field-error-msg,
.cc-details.hidden .help-block,
#inputDescriptionContainer.hidden .help-block,
.form-group.hidden .help-block {
    display: none !important;
}

.agive-topbar {
    padding: 18px 24px;
}

.agive-page-title {
    font-size: 20px;
    margin: 0 0 4px;
}

.agive-page-subtitle {
    font-size: 14px;
    color: var(--agive-text-soft);
    margin: 0;
}

.agive-shortcut-card__count {
    display: block;
    font-size: 38px;
    line-height: 1;
    font-weight: 800;
    color: var(--agive-primary);
    margin-bottom: 14px;
}

/* ===== Store / Products ===== */

.agive-store-page {
    width: 100%;
}

.agive-store-layout {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 24px;
    align-items: start;
}

.agive-store-sidebar {
    position: sticky;
    top: 24px;
}

.agive-store-content {
    min-width: 0;
}

.agive-store-hero {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 28px;
    padding: 28px;
    box-shadow: var(--agive-shadow-soft);
    margin-bottom: 22px;
}

.agive-store-badge {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    background: var(--agive-surface-soft);
    color: var(--agive-primary);
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 16px;
}

.agive-store-title {
    margin: 0 0 10px;
    color: var(--agive-primary);
    font-size: 40px;
    line-height: 1.05;
    font-weight: 800;
}

.agive-store-subtitle {
    margin: 0;
    color: var(--agive-text-soft);
    font-size: 17px;
    max-width: 760px;
}

.agive-store-mobile-categories {
    display: none;
    margin-bottom: 18px;
}

.agive-store-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}

.agive-product-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 100%;
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
    padding: 24px;
}

.agive-product-card__title {
    margin: 0;
    color: var(--agive-primary);
    font-size: 26px;
    line-height: 1.1;
    font-weight: 800;
}

.agive-product-card__stock {
    display: inline-flex;
    align-items: center;
    margin-top: 10px;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(46, 155, 98, 0.10);
    color: var(--agive-success);
    font-size: 12px;
    font-weight: 700;
}

.agive-product-card__body {
    margin-top: 18px;
}

.agive-product-card__description {
    margin: 0 0 16px;
    color: var(--agive-text-soft);
    line-height: 1.7;
}

.agive-product-card__features {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 10px;
}

.agive-product-card__features li {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--agive-border);
    color: var(--agive-text-soft);
    line-height: 1.5;
}

.agive-product-card__features li:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.agive-product-card__features .feature-value {
    color: var(--agive-primary);
    font-weight: 700;
    white-space: nowrap;
}

.agive-product-card__footer {
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid var(--agive-border);
}

.agive-product-card__from,
.agive-product-card__bundle,
.agive-product-card__cycle,
.agive-product-card__setup {
    color: var(--agive-text-soft);
}

.agive-product-card__from,
.agive-product-card__bundle {
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 6px;
}

.agive-product-card__price {
    color: var(--agive-primary);
    font-size: 34px;
    line-height: 1;
    font-weight: 800;
    margin-bottom: 8px;
}

.agive-product-card__cycle {
    font-size: 14px;
    margin-bottom: 4px;
}

.agive-product-card__setup {
    font-size: 13px;
}

.agive-product-card__button {
    width: 100%;
    margin-top: 18px;
    gap: 10px;
}

/* Sidebar do standard_cart */
#order-standard_cart .cart-sidebar.sidebar,
#order-standard_cart .sidebar {
    width: 100%;
    float: none;
}

#order-standard_cart .cart-body {
    width: 100%;
    float: none;
}

#order-standard_cart .panel-sidebar,
#order-standard_cart .sidebar-categories,
#order-standard_cart .list-group {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 22px;
    box-shadow: var(--agive-shadow-soft);
    overflow: hidden;
}

#order-standard_cart .panel-sidebar .panel-heading,
#order-standard_cart .sidebar-categories .panel-heading {
    background: transparent;
    color: var(--agive-primary);
    border-bottom: 1px solid var(--agive-border);
    font-weight: 800;
}

#order-standard_cart .list-group-item {
    border-left: 0;
    border-right: 0;
}

#order-standard_cart .list-group-item:first-child {
    border-top: 0;
}

#order-standard_cart .list-group-item:last-child {
    border-bottom: 0;
}

#order-standard_cart .list-group-item.active,
#order-standard_cart .list-group-item.active:hover,
#order-standard_cart .list-group-item.active:focus {
    background: rgba(33, 62, 96, 0.08);
    color: var(--agive-primary);
    border-color: var(--agive-border);
    font-weight: 700;
}

/* Esconde o header antigo do standard cart */
#order-standard_cart .header-lined {
    display: none;
}

/* ===== Sidebar custom da store ===== */

.agive-store-sidebar-panel {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 22px;
    box-shadow: var(--agive-shadow-soft);
    overflow: hidden;
}

.agive-store-sidebar-panel + .agive-store-sidebar-panel {
    margin-top: 16px;
}

.agive-store-sidebar-panel__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 16px 18px;
    border-bottom: 1px solid var(--agive-border);
}

.agive-store-sidebar-panel__title {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
    color: var(--agive-primary);
    font-size: 18px;
    font-weight: 800;
    line-height: 1.3;
}

.agive-store-sidebar-panel__title i {
    flex-shrink: 0;
}

.agive-store-sidebar-panel__toggle {
    flex-shrink: 0;
    color: var(--agive-text-soft);
    font-size: 13px;
}

.agive-store-sidebar-panel__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 22px;
    padding: 0 8px;
    border-radius: 999px;
    background: rgba(33, 62, 96, 0.08);
    color: var(--agive-primary);
    font-size: 11px;
    font-weight: 700;
}

.agive-store-sidebar-panel__body,
.agive-store-sidebar-panel__footer {
    padding: 14px 18px;
}

.agive-store-sidebar-panel__footer {
    border-top: 1px solid var(--agive-border);
}

.agive-store-sidebar-panel__list {
    display: flex;
    flex-direction: column;
}

.agive-store-sidebar-panel__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
    min-height: 48px;
    padding: 12px 18px;
    border-bottom: 1px solid var(--agive-border);
    color: var(--agive-primary);
    text-decoration: none;
    line-height: 1.45;
    background: #fff;
    box-sizing: border-box;
    word-break: break-word;
}

.agive-store-sidebar-panel__item:last-child {
    border-bottom: 0;
}

.agive-store-sidebar-panel__item:hover {
    background: #faf7f1;
    color: var(--agive-primary);
    text-decoration: none;
}

.agive-store-sidebar-panel__item.active,
.agive-store-sidebar-panel__item.active:hover,
.agive-store-sidebar-panel__item.active:focus {
    background: rgba(33, 62, 96, 0.08);
    color: var(--agive-primary);
    font-weight: 700;
}

.agive-store-sidebar-panel__item.disabled {
    opacity: 0.55;
    pointer-events: none;
}

.agive-store-sidebar-panel__item-left {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.agive-store-sidebar-panel__item-left i {
    flex-shrink: 0;
}

.agive-store-sidebar-mobile {
    margin-top: 14px;
}

/* neutraliza estilos antigos do standard_cart nessa sidebar */
.agive-store-sidebar-panel .panel,
.agive-store-sidebar-panel .panel-heading,
.agive-store-sidebar-panel .panel-title,
.agive-store-sidebar-panel .list-group,
.agive-store-sidebar-panel .list-group-item {
    all: unset;
}

/* ===== Modal / bloco de recomendações do standard_cart ===== */

.recommendations-container,
#recommendationsModal,
.modal-recommendations,
#order-standard_cart .modal,
#order-standard_cart .recommendations {
    font-family: 'Inter', Arial, sans-serif;
}

#recommendationsModal .modal-dialog,
#order-standard_cart .modal-dialog {
    max-width: 960px;
}

#recommendationsModal .modal-content,
#order-standard_cart .modal-content {
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
    overflow: hidden;
}

#recommendationsModal .modal-header,
#order-standard_cart .modal-header {
    background: #fff;
    border-bottom: 1px solid var(--agive-border);
    padding: 20px 24px;
}

#recommendationsModal .modal-title,
#order-standard_cart .modal-title {
    color: var(--agive-primary);
    font-size: 24px;
    font-weight: 800;
}

#recommendationsModal .close,
#order-standard_cart .close {
    opacity: 1;
    color: var(--agive-primary);
    font-size: 22px;
    text-shadow: none;
    box-shadow: none;
    border: 0;
    background: transparent;
}

#recommendationsModal .modal-body,
#order-standard_cart .modal-body {
    background: var(--agive-bg);
    padding: 24px;
}

#recommendationsModal .modal-footer,
#order-standard_cart .modal-footer {
    background: #fff;
    border-top: 1px solid var(--agive-border);
    padding: 18px 24px;
}

/* cards dentro da recomendação */
#recommendationsModal .product,
#recommendationsModal .recommendation,
#recommendationsModal .item,
#order-standard_cart .recommendation,
#order-standard_cart .product,
#order-standard_cart .recommendations .item {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 20px;
    box-shadow: var(--agive-shadow-soft);
    padding: 18px;
    margin-bottom: 16px;
}

#recommendationsModal .product-title,
#recommendationsModal h3,
#order-standard_cart .recommendation h3,
#order-standard_cart .product-title {
    color: var(--agive-primary);
    font-weight: 800;
}

/* botão continuar / ações */
#recommendationsModal .btn,
#order-standard_cart .modal .btn {
    border-radius: 14px !important;
    min-height: 46px;
    padding: 0 18px !important;
    font-weight: 700 !important;
}

#recommendationsModal .btn-primary,
#order-standard_cart .modal .btn-primary {
    background: var(--agive-primary) !important;
    border-color: var(--agive-primary) !important;
    color: #fff !important;
}

#recommendationsModal .btn-default,
#order-standard_cart .modal .btn-default,
#recommendationsModal .btn-secondary,
#order-standard_cart .modal .btn-secondary {
    background: var(--agive-surface-soft) !important;
    border-color: var(--agive-surface-soft) !important;
    color: var(--agive-primary) !important;
}

/* quando ele aparece "solto" na página */
.recommendations-container,
#recommendationsModal:not(.modal),
#order-standard_cart .recommendations:not(.modal) {
    margin-top: 28px;
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
    padding: 24px;
}

.recommendations-container h2,
.recommendations-container h3,
#order-standard_cart .recommendations h2,
#order-standard_cart .recommendations h3 {
    color: var(--agive-primary);
    font-weight: 800;
}

.recommendations-container .btn,
#order-standard_cart .recommendations .btn {
    border-radius: 14px !important;
}

/* ===== Recomendações / adicionado ao carrinho ===== */

.agive-recommendations-modal__dialog {
    max-width: 980px;
}

.agive-recommendations-modal__content {
    border: 1px solid var(--agive-border);
    border-radius: 26px;
    box-shadow: var(--agive-shadow-soft);
    overflow: hidden;
    background: #fff;
}

.agive-recommendations-modal__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 22px 24px;
    border-bottom: 1px solid var(--agive-border);
    background: #fff;
}

.agive-recommendations-modal__title-wrap {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.agive-recommendations-modal__title {
    margin: 0;
    color: var(--agive-primary);
    font-size: 28px;
    line-height: 1.1;
    font-weight: 800;
}

.agive-recommendations-modal__close {
    opacity: 1;
    color: var(--agive-primary);
    font-size: 24px;
    text-shadow: none;
    border: 0;
    background: transparent;
    box-shadow: none;
    padding: 0;
    line-height: 1;
}

.agive-recommendations-modal__body {
    padding: 24px;
    background: var(--agive-bg);
}

.agive-recommendations-modal__footer {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding: 18px 24px 24px;
    border-top: 1px solid var(--agive-border);
    background: #fff;
}

/* card clonável de recomendação */
.agive-recommendation-card {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 22px;
    box-shadow: var(--agive-shadow-soft);
    overflow: hidden;
}

.agive-recommendation-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 22px 0;
}

.agive-recommendation-card__content {
    min-width: 0;
}

.agive-recommendation-card__headline {
    color: var(--agive-primary);
    font-size: 22px;
    line-height: 1.15;
    font-weight: 800;
    margin-bottom: 6px;
}

.agive-recommendation-card__tagline {
    color: var(--agive-text-soft);
    line-height: 1.5;
}

.agive-recommendation-card__expander {
    flex-shrink: 0;
    color: var(--agive-text-soft);
    padding-top: 2px;
}

.agive-recommendation-card__body {
    padding: 16px 22px 0;
    color: var(--agive-text-soft);
    line-height: 1.7;
}

.agive-recommendation-card__body p {
    margin: 0;
}

.agive-recommendation-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 22px 22px;
}

.agive-recommendation-card__price-wrap {
    min-width: 0;
}

.agive-recommendation-card__price {
    color: var(--agive-primary);
    font-size: 28px;
    line-height: 1;
    font-weight: 800;
}

.agive-recommendation-card__price .setup-fee {
    color: var(--agive-text-soft);
    font-size: 13px;
    font-weight: 600;
}

.agive-recommendation-card .btn-add {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 46px;
}

.agive-recommendation-card .arrow {
    display: inline-flex;
    align-items: center;
}

/* se aparecer solto fora do modal */
#recommendationsModal.modal {
    z-index: 1200;
}

#recommendationsModal .modal-body .row,
#recommendationsModal .modal-body .products,
#recommendationsModal .modal-body .product-recommendations {
    row-gap: 18px;
}

@media (max-width: 767px) {
    .agive-recommendations-modal__header,
    .agive-recommendations-modal__body,
    .agive-recommendations-modal__footer {
        padding-left: 18px;
        padding-right: 18px;
    }

    .agive-recommendations-modal__title {
        font-size: 24px;
    }

    .agive-recommendation-card__footer {
        flex-direction: column;
        align-items: stretch;
    }

    .agive-recommendation-card .btn-add {
        width: 100%;
        justify-content: center;
    }

    .agive-recommendation-card__price {
        font-size: 24px;
    }
}

/* Esconde recomendações enquanto o modal não estiver aberto */
#recommendationsModal {
    display: none !important;
}

#recommendationsModal.in,
#recommendationsModal.show {
    display: block !important;
}

/* garante overlay/modal acima do conteúdo */
#recommendationsModal.modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
}

/* ===== Configure Product - layout organizado ===== */

#order-standard_cart .cart-sidebar {
    display: none !important;
}

#order-standard_cart .cart-body {
    width: 100% !important;
    float: none !important;
}

#order-standard_cart form#frmConfigureProduct {
    display: block;
}

#order-standard_cart .secondary-cart-body {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 380px;
    gap: 28px;
    align-items: start;
}

#order-standard_cart .secondary-cart-body > div:first-child {
    min-width: 0;
}

#order-standard_cart .secondary-cart-sidebar {
    width: 100%;
    flex: none;
    position: sticky;
    top: 24px;
}

/* layout principal */
.agive-configure-page .secondary-cart-body {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 24px;
}

/* coluna esquerda */
.agive-configure-page .secondary-cart-body > div:first-child {
    display: grid;
    gap: 20px;
}

/* sidebar direita */
.agive-configure-page .secondary-cart-sidebar {
    position: sticky;
    top: 24px;
}

/* layout principal */
.agive-configure-page .secondary-cart-body {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 24px;
}

/* coluna esquerda */
.agive-configure-page .secondary-cart-body > div:first-child {
    display: grid;
    gap: 20px;
}

/* sidebar direita */
.agive-configure-page .secondary-cart-sidebar {
    position: sticky;
    top: 24px;
}

.agive-configure-page .sub-heading,
.agive-configure-page .product-info,
.agive-configure-page .field-container,
.agive-configure-page #productAddonsContainer {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 22px;
    box-shadow: var(--agive-shadow-soft);
    padding: 20px;
}

/* título */
.agive-configure-page .sub-heading span {
    background: none !important;
    color: var(--agive-primary);
    font-size: 22px;
    font-weight: 800;
}

.agive-configure-page #orderSummary {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
    padding: 20px;
}

.agive-configure-page #orderSummary h2 {
    color: var(--agive-primary);
    font-weight: 800;
}

.agive-configure-page #btnCompleteProductConfig {
    width: 100%;
    border-radius: 16px;
    min-height: 50px;
}

/* ===== Configure Product - layout organizado ===== */

#order-standard_cart .cart-sidebar {
    display: none !important;
}

#order-standard_cart .cart-body {
    width: 100% !important;
    float: none !important;
}

#order-standard_cart form#frmConfigureProduct {
    display: block;
}

#order-standard_cart .secondary-cart-body {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 380px;
    gap: 28px;
    align-items: start;
}

#order-standard_cart .secondary-cart-body > div:first-child {
    min-width: 0;
}

#order-standard_cart .secondary-cart-sidebar {
    width: 100%;
    flex: none;
    position: sticky;
    top: 24px;
}

#order-standard_cart .field-container {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
    padding: 22px;
    margin: 0;
}

#order-standard_cart .field-container label {
    display: block;
    margin-bottom: 10px;
    color: var(--agive-text-soft);
    font-size: 14px;
    font-weight: 600;
}

#order-standard_cart .field-container .form-group {
    margin-bottom: 0;
}

#order-standard_cart .product-info {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
    padding: 24px;
    margin: 0;
}

#order-standard_cart .product-title {
    margin: 0 0 14px;
    color: var(--agive-primary);
    font-size: 34px;
    line-height: 1.05;
    font-weight: 800;
}

#order-standard_cart .product-info p {
    color: var(--agive-text-soft);
    line-height: 1.75;
}

#order-standard_cart .field-container {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
    padding: 22px;
    margin: 0;
}

#order-standard_cart .field-container label {
    display: block;
    margin-bottom: 10px;
    color: var(--agive-text-soft);
    font-size: 14px;
    font-weight: 600;
}

#order-standard_cart .field-container .form-group {
    margin-bottom: 0;
}

#order-standard_cart .order-summary {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
    overflow: hidden;
}

#order-standard_cart .order-summary h2 {
    margin: 0;
    padding: 22px 24px 0;
    color: var(--agive-primary);
    font-size: 24px;
    line-height: 1.1;
    font-weight: 800;
}

#order-standard_cart .summary-container {
    padding: 20px 24px;
}

#order-standard_cart .summary-container .price,
#order-standard_cart .summary-container .amt,
#order-standard_cart .summary-container .total-due-today,
#order-standard_cart .summary-container .recurring-amt {
    color: var(--agive-primary);
    font-weight: 800;
}

#order-standard_cart #btnCompleteProductConfig {
    width: 100%;
    min-height: 54px;
    margin-top: 18px;
    border-radius: 16px !important;
    background: var(--agive-primary) !important;
    border-color: var(--agive-primary) !important;
    color: #fff !important;
    font-size: 16px;
    font-weight: 700 !important;
    box-shadow: none !important;
}

#order-standard_cart .header-lined {
    display: none !important;
}

#order-standard_cart .cart-sidebar {
    display: none !important;
}

/* ===== Etapa de domínio no configure product ===== */

#order-standard_cart .domain-selection-options {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

#order-standard_cart .domain-option,
#order-standard_cart .domain-selection-options .option,
#order-standard_cart .domain-selection-options .domain-option-card {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 20px;
    box-shadow: var(--agive-shadow-soft);
    overflow: hidden;
}

#order-standard_cart .domain-option label,
#order-standard_cart .domain-selection-options label {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 18px;
    margin: 0;
    color: var(--agive-primary);
    font-weight: 700;
    cursor: pointer;
}

#order-standard_cart .domain-option input[type="radio"],
#order-standard_cart .domain-selection-options input[type="radio"] {
    width: 18px;
    height: 18px;
    margin: 0;
    accent-color: var(--agive-primary);
    flex-shrink: 0;
}

#order-standard_cart .domain-option.active,
#order-standard_cart .domain-selection-options .option-selected,
#order-standard_cart .domain-option:has(input[type="radio"]:checked) {
    border-color: var(--agive-primary);
    background: rgba(33, 62, 96, 0.04);
}

/* bloco interno da opção selecionada */
#order-standard_cart .domain-input-group,
#order-standard_cart .domain-option .domain-form,
#order-standard_cart .register-domain-fields {
    padding: 0 18px 18px;
    border-top: 1px solid var(--agive-border);
    background: #fff;
}

/* campo www + domínio */
#order-standard_cart .domain-input-group .row,
#order-standard_cart .register-domain-fields .row {
    margin-left: 0;
    margin-right: 0;
}

#order-standard_cart .domain-input-group [class*="col-"],
#order-standard_cart .register-domain-fields [class*="col-"] {
    padding-left: 0;
    padding-right: 0;
}

#order-standard_cart .domain-input-group label,
#order-standard_cart .register-domain-fields label {
    display: block;
    margin: 14px 0 8px;
    padding: 0;
    color: var(--agive-text-soft);
    font-size: 14px;
    font-weight: 600;
}

#order-standard_cart .domain-input-group .form-control,
#order-standard_cart .register-domain-fields .form-control,
#order-standard_cart .domain-selection-options .form-control,
#order-standard_cart .domain-selection-options input[type="text"],
#order-standard_cart .domain-selection-options select {
    width: 100%;
    min-height: 46px;
    border: 1px solid var(--agive-border) !important;
    border-radius: 14px !important;
    padding: 10px 14px !important;
    background: #fff !important;
    box-shadow: none !important;
}

/* botão verificar */
#order-standard_cart .btn-domain-check,
#order-standard_cart .domain-checker-btn,
#order-standard_cart button[name="domainoption"][value="register"],
#order-standard_cart .btn.check-availability,
#order-standard_cart .domain-selection-options .btn {
    border-radius: 14px !important;
    min-height: 44px;
    padding: 0 18px !important;
    font-weight: 700 !important;
    background: var(--agive-primary) !important;
    border-color: var(--agive-primary) !important;
    color: #fff !important;
    box-shadow: none !important;
}

/* opções não selecionadas mais discretas */
#order-standard_cart .domain-selection-options > div:not(:has(input[type="radio"]:checked)) label:hover,
#order-standard_cart .domain-option:not(:has(input[type="radio"]:checked)) label:hover {
    background: #faf7f1;
}

/* ajuda/avisos */
#order-standard_cart .domain-selection-options .help-block,
#order-standard_cart .domain-selection-options .text-muted {
    color: var(--agive-text-soft) !important;
}

/* espaçamento geral */
#order-standard_cart .domain-selection-options {
    margin-top: 6px;
}

/* mobile */
@media (max-width: 767px) {
    #order-standard_cart .domain-option label,
    #order-standard_cart .domain-selection-options label {
        align-items: flex-start;
    }

    #order-standard_cart .domain-input-group,
    #order-standard_cart .register-domain-fields {
        padding: 0 14px 14px;
    }
}

/* ===== DOMÍNIO - AGIVE ===== */

.agive-domain-selection {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-top: 10px;
}

/* ===== CARD ===== */
.agive-domain-selection .option {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 20px;
    box-shadow: var(--agive-shadow-soft);
    overflow: hidden;
    transition: all .2s ease;
}

.agive-domain-selection .option:hover {
    border-color: var(--agive-primary);
}

/* ===== HEADER DO CARD ===== */
.agive-domain-selection .option > label {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 18px;
    margin: 0;
    cursor: pointer;
    font-weight: 700;
    color: var(--agive-primary);
}

/* RADIO */
.agive-domain-selection input[type="radio"] {
    width: 18px;
    height: 18px;
    accent-color: var(--agive-primary);
}

/* CARD ATIVO */
.agive-domain-selection .option:has(input:checked) {
    border-color: var(--agive-primary);
    background: rgba(33, 62, 96, 0.04);
}

/* ===== CONTEÚDO ===== */
.agive-domain-selection .domain-input-group {
    padding: 18px;
    border-top: 1px solid var(--agive-border);
}

/* ===== INPUTS ===== */
.agive-domain-selection .form-control,
.agive-domain-selection input,
.agive-domain-selection select {
    border-radius: 14px !important;
    border: 1px solid var(--agive-border) !important;
    min-height: 46px;
    padding: 10px 14px !important;
    box-shadow: none !important;
}

/* ===== WWW PREFIX ===== */
.agive-domain-selection .input-group-text {
    background: #faf7f1 !important;
    border-radius: 14px 0 0 14px !important;
    border: 1px solid var(--agive-border) !important;
    border-right: none !important;
}

/* ===== BOTÃO ===== */
.agive-domain-selection .btn {
    height: 46px;
    border-radius: 14px !important;
    font-weight: 700 !important;
    background: var(--agive-primary) !important;
    border-color: var(--agive-primary) !important;
    color: #fff !important;
}

/* ===== GRID INPUT ===== */
.agive-domain-selection .domains-row {
    display: flex;
    gap: 10px;
}

.agive-domain-selection .domains-row > div {
    padding: 0 !important;
}

/* ===== TEXTO ===== */
.agive-domain-selection label {
    font-size: 15px;
}

/* ===== RESULTADOS ===== */
#DomainSearchResults {
    margin-top: 20px;
}

/* ===== BOTÃO CONTINUAR ===== */
#btnDomainContinue {
    margin-top: 20px;
    border-radius: 16px !important;
    height: 52px;
    font-size: 16px;
    font-weight: 700;
}

/* ===== MOBILE ===== */
@media (max-width: 767px) {

    .agive-domain-selection .domains-row {
        flex-direction: column;
    }

    .agive-domain-selection .btn {
        width: 100%;
        margin-top: 10px;
    }

}

/* ===== Ajuste fino dos campos de domínio ===== */

.agive-domain-selection .domain-input-group {
    padding: 20px;
    border-top: 1px solid var(--agive-border);
    background: #fff;
}

.agive-domain-selection .domain-input-group .row {
    margin-left: 0 !important;
    margin-right: 0 !important;
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    align-items: flex-end;
}

.agive-domain-selection .domain-input-group [class*="col-"] {
    padding-left: 0 !important;
    padding-right: 0 !important;
    float: none !important;
}

/* coluna principal com domínio */
.agive-domain-selection .domain-input-group .col-sm-8,
.agive-domain-selection .domain-input-group .col-sm-9,
.agive-domain-selection .domain-input-group .col-sm-8.col-sm-offset-1,
.agive-domain-selection .domain-input-group .col-sm-9.col-sm-offset-1,
.agive-domain-selection .domain-input-group .col-md-6.col-md-offset-2 {
    flex: 1 1 520px;
    max-width: none;
    margin-left: 0 !important;
}

/* coluna do botão */
.agive-domain-selection .domain-input-group .col-sm-2 {
    flex: 0 0 140px;
    max-width: 140px;
}

/* linha interna do domínio */
.agive-domain-selection .domains-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 120px;
    gap: 12px;
    align-items: end;
    width: 100%;
}

/* quando existe www + tld */
.agive-domain-selection .domains-row .col-xs-9,
.agive-domain-selection .domains-row .col-9 {
    width: auto !important;
    max-width: none !important;
    flex: none !important;
}

.agive-domain-selection .domains-row .col-xs-3,
.agive-domain-selection .domains-row .col-3 {
    width: auto !important;
    max-width: none !important;
    flex: none !important;
}

.agive-domain-selection .input-group {
    display: flex;
    align-items: stretch;
    width: 100%;
}

.agive-domain-selection .input-group-addon,
.agive-domain-selection .input-group-prepend,
.agive-domain-selection .input-group-text {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-width: 74px;
    padding: 0 14px;
    background: #faf7f1 !important;
    border: 1px solid var(--agive-border) !important;
    border-right: 0 !important;
    border-radius: 14px 0 0 14px !important;
    color: var(--agive-primary);
    font-weight: 700;
    white-space: nowrap;
}

.agive-domain-selection .input-group .form-control {
    border-radius: 0 14px 14px 0 !important;
    border-left: 0 !important;
}

/* campos gerais */
.agive-domain-selection .form-control,
.agive-domain-selection input[type="text"],
.agive-domain-selection select {
    width: 100%;
    min-height: 46px;
    border: 1px solid var(--agive-border) !important;
    border-radius: 14px !important;
    padding: 10px 14px !important;
    background: #fff !important;
    box-shadow: none !important;
}

/* quando o campo está dentro de input-group, evita dupla borda arredondada */
.agive-domain-selection .input-group input.form-control {
    min-width: 0;
}

/* botão verificar / usar / transferir */
.agive-domain-selection .domain-input-group .btn,
.agive-domain-selection .domain-input-group .btn-primary,
.agive-domain-selection .domain-input-group button[type="submit"] {
    width: 100%;
    min-height: 46px;
    border-radius: 14px !important;
    background: var(--agive-primary) !important;
    border-color: var(--agive-primary) !important;
    color: #fff !important;
    font-weight: 700 !important;
    box-shadow: none !important;
    padding: 0 18px !important;
}

/* espaçamento do conteúdo interno */
.agive-domain-selection .domain-input-group .form-control-static {
    min-height: 46px;
    display: inline-flex;
    align-items: center;
    color: var(--agive-text-soft);
    padding: 0 6px;
}

/* card ativo */
.agive-domain-selection .option:has(input[type="radio"]:checked) {
    border-color: var(--agive-primary);
    background: rgba(33, 62, 96, 0.04);
}

/* cards inativos */
.agive-domain-selection .option > label {
    min-height: 58px;
}

/* mobile */
@media (max-width: 767px) {
    .agive-domain-selection .domain-input-group .row {
        flex-direction: column;
        align-items: stretch;
    }

    .agive-domain-selection .domain-input-group .col-sm-2,
    .agive-domain-selection .domain-input-group .col-sm-8,
    .agive-domain-selection .domain-input-group .col-sm-9,
    .agive-domain-selection .domain-input-group .col-md-6.col-md-offset-2 {
        flex: 1 1 auto;
        max-width: none;
        width: 100%;
    }

    .agive-domain-selection .domains-row {
        grid-template-columns: 1fr;
    }

    .agive-domain-selection .input-group-addon,
    .agive-domain-selection .input-group-prepend,
    .agive-domain-selection .input-group-text {
        min-width: 64px;
    }

    .agive-domain-selection .domain-input-group {
        padding: 16px;
    }
}

.view-cart-items .item {
    background: #fff;
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 12px;
    border: 1px solid #eee;
}

.item-title {
    font-weight: 600;
    color: #213E60;
}

.item-price {
    text-align: right;
    font-weight: 600;
}

.modal-remove-item .modal-content {
    border-radius: 16px;
    padding: 20px;
    text-align: center;
}

.modal-remove-item .modal-title i {
    color: #dc3545;
}

.modal-remove-item .modal-content {
    border-radius: 16px;
    padding: 20px;
    text-align: center;
}

.modal-remove-item .modal-title i {
    color: #dc3545;
}

.agv-cart-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #fff;
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 12px;
    border: 1px solid #eee;
}

.agv-cart-item-right {
    text-align: right;
}

.agv-summary-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
}

.agv-summary-total {
    display: flex;
    justify-content: space-between;
    font-size: 18px;
    font-weight: bold;
    margin-top: 15px;
}

/* ===== View Cart / Resumo do Pedido ===== */

.agv-page {
    width: 100%;
}

.agv-page-header {
    margin-bottom: 24px;
}

.agv-page-header h1 {
    margin: 0 0 8px;
    color: var(--agive-primary);
    font-size: 42px;
    line-height: 1.05;
    font-weight: 800;
}

.agv-page-header p {
    margin: 0;
    color: var(--agive-text-soft);
    font-size: 17px;
}

.agv-card,
.agv-summary-card {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
    overflow: hidden;
}

.agv-card-header,
.agv-summary-header {
    padding: 22px 24px 0;
}

.agv-card-header h3,
.agv-summary-header h3 {
    margin: 0;
    color: var(--agive-primary);
    font-size: 24px;
    line-height: 1.1;
    font-weight: 800;
}

.agv-card-body,
.agv-summary-body {
    padding: 20px 24px 24px;
}

.agv-summary-footer {
    padding: 0 24px 24px;
}

.agv-cart-item:first-child {
    padding-top: 0;
}

.agv-cart-item:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.agv-cart-item-left {
    min-width: 0;
    flex: 1 1 auto;
}

.agv-cart-item-left strong {
    display: block;
    color: var(--agive-primary);
    font-size: 22px;
    font-weight: 800;
    margin-bottom: 4px;
}

.agv-cart-item-left .text-muted,
.agv-cart-item-left small {
    color: var(--agive-text-soft) !important;
    font-size: 15px;
}

.agv-cart-item-right {
    text-align: right;
    flex: 0 0 180px;
}

.agv-cart-item-right > span {
    display: block;
    color: var(--agive-primary);
    font-size: 24px;
    font-weight: 800;
    margin-bottom: 4px;
}

.agv-cart-item-right small {
    display: block;
    color: var(--agive-text-soft);
    margin-bottom: 10px;
}

.agv-remove-link {
    background: transparent;
    border: 0;
    color: #c24141;
    font-weight: 700;
    padding: 0;
    cursor: pointer;
}

.agv-remove-link:hover {
    color: #a83232;
    text-decoration: underline;
}

.agv-summary-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 10px 0;
    color: var(--agive-text-soft);
}

.agv-summary-row strong {
    color: var(--agive-primary);
    font-weight: 800;
}

.agv-summary-total {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 14px;
    padding-top: 18px;
    border-top: 1px solid var(--agive-border);
}

.agv-summary-total span {
    color: var(--agive-primary);
    font-size: 16px;
    font-weight: 700;
}

.agv-summary-total strong {
    color: var(--agive-primary);
    font-size: 32px;
    line-height: 1;
    font-weight: 800;
}

.agv-card .form-control {
    width: 100%;
    min-height: 46px;
    border: 1px solid var(--agive-border) !important;
    border-radius: 14px !important;
    padding: 10px 14px !important;
    background: #fff !important;
    box-shadow: none !important;
}

@media (max-width: 991px) {
    .agv-page-header h1 {
        font-size: 32px;
    }

    .agv-cart-item {
        flex-direction: column;
    }

    .agv-cart-item-right {
        text-align: left;
        width: 100%;
        flex: 1 1 auto;
    }

    .agv-cart-item-right > span {
        font-size: 22px;
    }

    .agv-summary-total strong {
        font-size: 26px;
    }
}

/* ===== Corrige grid do carrinho ===== */

.agv-page .row {
    display: flex;
    flex-wrap: wrap;
    margin-left: -12px;
    margin-right: -12px;
}

.agv-page .col-lg-8,
.agv-page .col-lg-4,
.agv-page .col-md-8,
.agv-page .col-md-4,
.agv-page .col-12 {
    position: relative;
    width: 100%;
    min-height: 1px;
    padding-left: 12px;
    padding-right: 12px;
}

@media (min-width: 992px) {
    .agv-page .col-lg-8 {
        flex: 0 0 66.666667%;
        max-width: 66.666667%;
    }

    .agv-page .col-lg-4 {
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }
}

@media (max-width: 991px) {
    .agv-page .col-lg-8,
    .agv-page .col-lg-4 {
        flex: 0 0 100%;
        max-width: 100%;
    }
}

.modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 1200;
    background: rgba(15, 23, 42, 0.45);
    overflow-y: auto;
    padding: 40px 16px;
}

.modal.show,
.modal.in {
    display: block;
}

.modal-dialog {
    max-width: 560px;
    margin: 0 auto;
}

.modal-content {
    background: #fff;
    border: 1px solid var(--agive-border);
    border-radius: 24px;
    box-shadow: var(--agive-shadow-soft);
    overflow: hidden;
}

.modal-body {
    padding: 24px;
}

.modal-footer {
    padding: 0 24px 24px;
    display: flex;
    justify-content: center;
    gap: 12px;
}

body.modal-open {
    overflow: hidden;
}

