/* ============================================================
   Consulenti Portal — Design System Pliin
   Colori, tipografia e componenti identici al sito pliin.it
   ============================================================ */

/* ── Variabili (1:1 con shared.css del sito) ── */
:root {
    --navy:          #213b8a;
    --navy-deep:     #0d1f5c;
    --cyan:          #009fe3;
    --cyan-soft:     #9fd3ec;
    --cyan-lighter:  #4fc0ee;
    --ink:           #0a0a1a;
    --bg-soft:       #f5f7ff;
    --white:         #ffffff;
    --text:          #0f1530;
    --text-mid:      #4a5578;
    --text-soft:     #324065;

    --radius-lg:     22px;
    --radius-md:     14px;
    --radius-sm:     8px;
    --radius-pill:   999px;

    --shadow-sm:     0 2px 8px  rgba(33,59,138,.08);
    --shadow-md:     0 12px 40px rgba(33,59,138,.18);
    --shadow-glow:   0 0 0 1px rgba(0,159,227,.5), 0 10px 40px rgba(0,159,227,.35);

    /* stato */
    --success:       #22c55e;
    --success-bg:    #dcfce7;
    --danger:        #ef4444;
    --danger-bg:     #fee2e2;
    --warning:       #f59e0b;
    --warning-bg:    #fef3c7;

    --font-body:     "DM Sans",    system-ui, sans-serif;
    --font-heading:  "Parkinsans", "DM Sans", sans-serif;

    --transition:    0.22s ease;
}

/* ============================================================
   BASE
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }

.cp-portal-wrap,
.cp-portal-wrap * { box-sizing: border-box; }

.cp-portal-wrap {
    font-family: var(--font-body) !important;
    color: var(--text);
    background: var(--bg-soft);
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    line-height: 1.55;
}

.cp-portal-wrap *:not(svg):not(path):not(circle):not(line):not(polyline):not(rect):not(polygon):not(ellipse) {
    font-family: inherit !important;
}

.cp-portal-inner {
    max-width: 1440px;
    margin: 0 auto;
    padding: 30px 30px;
}

.cp-portal-wrap h1,
.cp-portal-wrap h2,
.cp-portal-wrap h3,
.cp-portal-wrap h4 {
    font-family: var(--font-heading);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.08;
    color: var(--navy);
    margin: 0 0 .5em;
}

.cp-portal-wrap h3 { font-size: 1.55rem; }

/* ============================================================
   NAVBAR
   ============================================================ */

.cp-navbar {
    background: rgba(255,255,255,.92);
    border-bottom: 1px solid rgba(33,59,138,.08);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    box-shadow: 0 1px 0 rgba(33,59,138,.06);
    position: sticky;
    top: 0;
    z-index: 200;
}

.cp-navbar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 28px;
    height: 64px;
}

/* Logo */
.cp-nav-logo-link {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    text-decoration: none !important;
}

.cp-nav-logo {
    height: 50px!important;
    width: auto;
    display: block;
}

/* Menu desktop */
.cp-nav-menu {
    display: flex;
    align-items: center;
    gap: 4px;
}

.cp-nav-item {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 14px;
    font-size: .855rem;
    font-weight: 500;
    color: var(--text-mid);
    text-decoration: none !important;
    border-radius: var(--radius-pill);
    transition: background var(--transition), color var(--transition);
    white-space: nowrap;
}

.cp-nav-item:hover {
    color: var(--navy);
    background: rgba(33,59,138,.06);
    text-decoration: none !important;
}

.cp-nav-item.cp-nav-active {
    color: var(--cyan);
    background: rgba(0,159,227,.08);
    font-weight: 600;
}

.cp-nav-logout {
    color: var(--text-mid);
    border: 1.5px solid rgba(33,59,138,.15);
    margin-left: 8px;
}

.cp-nav-logout:hover {
    color: var(--danger) !important;
    border-color: var(--danger) !important;
    background: var(--danger-bg) !important;
}

/* Hamburger */
.cp-nav-hamburger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    background: none;
    border: 1.5px solid rgba(33,59,138,.18);
    border-radius: var(--radius-sm);
    cursor: pointer;
    padding: 8px 10px;
    width: 42px;
    height: 42px;
    flex-shrink: 0;
}

.cp-hamburger-line {
    display: block;
    width: 100%;
    height: 2px;
    background: var(--navy);
    border-radius: 2px;
    transition: transform .25s, opacity .25s;
    transform-origin: center;
}

.cp-navbar.is-open .cp-hamburger-line:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.cp-navbar.is-open .cp-hamburger-line:nth-child(2) { opacity: 0; transform: scaleX(0); }
.cp-navbar.is-open .cp-hamburger-line:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Menu mobile */
@media (max-width: 768px) {
    .cp-nav-hamburger { display: flex; }

    .cp-nav-menu {
        display: none;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        position: absolute;
        top: 64px;
        left: 0;
        right: 0;
        background: #fff;
        border-bottom: 1px solid rgba(33,59,138,.1);
        box-shadow: 0 8px 32px rgba(33,59,138,.12);
        padding: 12px 16px 20px;
        z-index: 199;
    }

    .cp-navbar.is-open .cp-nav-menu { display: flex; }

    .cp-nav-item {
        padding: 12px 14px;
        border-radius: var(--radius-md);
        font-size: .9rem;
    }

    .cp-nav-logout { margin-left: 0; margin-top: 8px; }
}

@media (max-width: 640px) {
    .cp-navbar-inner { padding: 0 16px; }
    .cp-portal-inner { padding: 30px 10px; }

    /* iOS Safari fa zoom automatico sugli input con font-size < 16px.
       Regola catch-all: copre qualsiasi input sulla pagina, inclusi
       i campi WooCommerce checkout che hanno selettori più specifici. */
    input,
    input[type="text"],
    input[type="email"],
    input[type="tel"],
    input[type="password"],
    input[type="search"],
    input[type="number"],
    input[type="url"],
    input[type="date"],
    select,
    textarea,
    .woocommerce-checkout input,
    .woocommerce-checkout select,
    .woocommerce-checkout textarea,
    .woocommerce input,
    .woocommerce select,
    .woocommerce textarea {
        font-size: 16px !important;
    }
    .cp-checkout-wrap #order_review {
        border: none!important;
        padding: 0px!important;
        box-shadow: none!important;
    }
    .woocommerce-order-pay .entry-content, .woocommerce-account .entry-content, .woocommerce-order-pay .woocommerce, .woocommerce-account .woocommerce {
        padding: 0 10px!important;
    }
    .woocommerce-order-pay table.shop_table th, .woocommerce-account table.shop_table th {
        padding: 10px 8px !important;
        font-size: 12px !important;
        white-space: break-spaces !important;
    }
    .woocommerce td.product-quantity {
        min-width: unset!important;
    }
    .woocommerce-order-pay #order_review, .woocommerce-account .woocommerce-MyAccount-content {
        padding: 32px 22px!important;
        box-sizing: border-box;
    }
}

/* ============================================================
   SEZIONE HEADER / SALUTO
   ============================================================ */

.cp-welcome { margin-bottom: 32px; }

.cp-welcome-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.cp-logout-btn {
    flex-shrink: 0;
    color: var(--text-mid);
    border-color: rgba(33,59,138,.18);
}

.cp-logout-btn:hover {
    color: var(--danger);
    border-color: var(--danger);
    background: var(--danger-bg);
}

.cp-welcome h2 {
    font-size: 2rem;
    font-weight: 800;
    margin: 0 0 6px;
}

.cp-welcome p {
    color: var(--text-mid);
    font-size: .95rem;
    margin: 0;
}

/* Kicker cyan (stile section-kicker del sito) */
.cp-kicker {
    display: inline-block;
    font-size: 12px;
    letter-spacing: .22em;
    text-transform: uppercase;
    font-weight: 600;
    color: var(--cyan);
    margin-bottom: 10px;
}

/* ============================================================
   STAT CARDS  (stile .why-stat ma su sfondo chiaro)
   ============================================================ */

.cp-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-bottom: 36px;
}

@media (max-width: 1024px) { .cp-stats-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px)  { .cp-stats-grid { grid-template-columns: 1fr; } }

.cp-stat-card {
    background: var(--white);
    border: 1px solid rgba(33,59,138,.1);
    border-radius: var(--radius-lg);
    padding: 28px 24px;
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: transform .3s, box-shadow .3s, border-color .3s;
    position: relative;
    overflow: hidden;
}

.cp-stat-card::after {
    content: "";
    position: absolute;
    inset: auto -20% -60% auto;
    width: 180px; height: 180px;
    background: radial-gradient(circle, rgba(0,159,227,.12), transparent 65%);
    opacity: 0;
    transition: opacity .3s;
    pointer-events: none;
}

.cp-stat-card:hover {
    transform: translateY(-4px);
    border-color: rgba(0,159,227,.35);
    box-shadow: var(--shadow-md);
}

.cp-stat-card:hover::after { opacity: 1; }

/* Card featured (navy gradient — come .price-card.light.featured) */
.cp-stat-card.cp-stat-featured {
    background: linear-gradient(160deg, #213b8a 0%, #0d1f5c 100%);
    border-color: rgba(0,159,227,.4);
    box-shadow: 0 12px 40px rgba(33,59,138,.35);
    color: #fff;
}

.cp-stat-card.cp-stat-featured::after { display: none; }

.cp-stat-card.cp-stat-featured .cp-stat-label,
.cp-stat-card.cp-stat-featured .cp-stat-icon-wrap {
    color: rgba(255,255,255,.7);
}

.cp-stat-card.cp-stat-featured .cp-stat-value { color: #fff; }
.cp-stat-card.cp-stat-featured:hover { box-shadow: 0 18px 50px rgba(33,59,138,.5); }

/* Icona */
.cp-stat-icon-wrap {
    color: var(--text-mid);
    font-size: 1.4rem;
    line-height: 1;
}

/* Valore numerico grande */
.cp-stat-value {
    font-family: var(--font-heading);
    font-size: 2.2rem;
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 1;
    color: var(--navy);
}

.cp-stat-value-row {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 8px;
}

.cp-stat-label {
    font-size: .82rem;
    color: var(--text-mid);
    font-weight: 500;
    letter-spacing: .01em;
}

/* Badge percentuale (pill) */
.cp-badge {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 4px 10px;
    border-radius: var(--radius-pill);
    font-size: .73rem;
    font-weight: 700;
    white-space: nowrap;
}

.cp-badge-up   { background: var(--success-bg); color: #15803d; }
.cp-badge-down { background: var(--danger-bg);  color: #b91c1c; }

.cp-stat-card.cp-stat-featured .cp-badge-up {
    background: rgba(255,255,255,.18);
    color: #fff;
}

.cp-badge-arrow { font-size: .6rem; }

/* ============================================================
   PULSANTI  (identici a .btn del sito, pill-shaped)
   ============================================================ */

.cp-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 13px 26px;
    border-radius: var(--radius-pill);
    border: none;
    font-family: var(--font-body);
    font-size: .9rem;
    font-weight: 600;
    text-decoration: none !important;
    cursor: pointer;
    transition: transform .25s cubic-bezier(.2,.9,.3,1.2), box-shadow .25s, background .25s;
    white-space: nowrap;
    line-height: 1.4;
}

.cp-btn:hover { transform: translateY(-2px); text-decoration: none !important; }

/* Primario: cyan come .btn-primary del sito */
.cp-btn-primary {
    background: var(--cyan);
    color: #fff;
    box-shadow: 0 0 0 1px rgba(255,255,255,.15) inset, 0 8px 24px rgba(0,159,227,.35);
}

.cp-btn-primary:hover {
    box-shadow: 0 0 0 1px rgba(255,255,255,.25) inset, 0 14px 40px rgba(0,159,227,.5);
    color: #fff;
}

/* Secondario: outline navy come .btn-outline */
.cp-btn-secondary {
    background: transparent;
    color: var(--navy);
    border: 1.5px solid rgba(33,59,138,.22);
}

.cp-btn-secondary:hover {
    border-color: var(--navy);
    background: var(--navy);
    color: #fff;
}

/* Navy pieno come .btn-dark */
.cp-btn-navy {
    background: var(--navy);
    color: #fff;
    box-shadow: 0 8px 24px rgba(33,59,138,.25);
}

.cp-btn-navy:hover {
    box-shadow: 0 14px 36px rgba(33,59,138,.4);
    color: #fff;
}

.cp-btn-large { padding: 16px 32px; font-size: 1rem; }
.cp-btn-sm    { padding: 7px 16px;  font-size: .8rem; }

/* Danger */
.cp-btn-danger {
    background: var(--danger-bg);
    color: var(--danger);
    border: 1px solid rgba(239,68,68,.25);
    border-radius: var(--radius-pill);
    box-shadow: none;
}

.cp-btn-danger:hover {
    background: var(--danger);
    color: #fff;
    border-color: var(--danger);
}

/* Aggiungi al carrello */
.cp-btn-add-to-cart {
    width: 100%;
    justify-content: center;
    background: var(--navy);
    color: #fff;
    border-radius: var(--radius-pill);
    font-size: .82rem;
    padding: 10px 14px;
    box-shadow: 0 4px 14px rgba(33,59,138,.2);
}

.cp-btn-add-to-cart:hover {
    background: var(--cyan);
    color: #fff;
    transform: none;
    box-shadow: var(--shadow-glow);
}

.cp-btn-add-to-cart.cp-added  { background: var(--success); pointer-events: none; }
.cp-btn-add-to-cart:disabled  { opacity: .55; pointer-events: none; }

/* ============================================================
   NOTICES
   ============================================================ */

.cp-notice {
    padding: 14px 18px;
    border-radius: var(--radius-md);
    margin: 16px 0;
    font-size: .875rem;
    font-weight: 500;
    border-left: 4px solid;
}

.cp-notice-success { background: var(--success-bg); border-color: var(--success); color: #15803d; }
.cp-notice-warning { background: var(--warning-bg); border-color: var(--warning); color: #92400e; }
.cp-notice-info    { background: #e8f5fd;            border-color: var(--cyan);    color: #0369a1; }
.cp-notice-danger  { background: var(--danger-bg);   border-color: var(--danger);  color: #b91c1c; }

/* ============================================================
   LAYOUT PAGINE
   ============================================================ */

.cp-portal-inner.cp-dashboard,
.cp-portal-inner.cp-crea-ordine,
.cp-portal-inner.cp-abbonamenti,
.cp-portal-inner.cp-account {
    padding-top: 40px;
}

/* ============================================================
   CTA DASHBOARD
   ============================================================ */

.cp-dashboard-cta {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 48px;
}

.cp-dashboard-cta img { filter: brightness(10); }

/* ============================================================
   CATALOGO PRODOTTI
   ============================================================ */

/* ── Header catalogo ── */
.cp-catalog-section h2,
.cp-checkout-section h2 {
    font-size: 1.4rem;
    margin: 0 0 20px;
}

.cp-catalog-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 36px;
}

.cp-catalog-header h2 { margin: 0; }

.cp-catalog-search { flex-shrink: 0; }

.cp-search-input {
    width: 100%;
    max-width: 320px;
    padding: 11px 20px;
    border: 1.5px solid rgba(33,59,138,.15);
    border-radius: var(--radius-pill);
    font-size: .9rem;
    font-family: var(--font-body);
    background: var(--white);
    color: var(--text);
    outline: none;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.cp-search-input:focus {
    border-color: var(--cyan);
    box-shadow: 0 0 0 3px rgba(0,159,227,.15);
}

.cp-search-input::placeholder { color: var(--text-mid); }

/* ── Sezione categoria ── */
.cp-cat-section { margin-bottom: 56px; }

.cp-cat-title {
    font-family: var(--font-heading);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--navy);
    margin: 0 0 24px;
    padding-bottom: 14px;
    border-bottom: 2px solid rgba(33,59,138,.08);
}

/* ── Griglia pricing ── */
.cp-price-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    align-items: start;
}

@media (max-width: 960px) { .cp-price-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px) { .cp-price-grid { grid-template-columns: 1fr; } }

/* ── Pricing card ── */
.cp-price-card {
    background: var(--white);
    border: 1.5px solid rgba(33,59,138,.1);
    border-radius: var(--radius-lg);
    padding: 32px 28px 28px;
    display: flex;
    flex-direction: column;
    gap: 0;
    box-shadow: var(--shadow-sm);
    transition: transform .3s, box-shadow .3s, border-color .3s;
    position: relative;
}

.cp-price-card:hover {
    transform: translateY(-5px);
    border-color: rgba(0,159,227,.3);
    box-shadow: 0 16px 40px rgba(33,59,138,.13);
}

/* Card in evidenza (prodotto featured in WooCommerce) */
.cp-price-card.cp-price-featured {
    background: linear-gradient(160deg, var(--navy) 0%, var(--navy-deep) 100%);
    border-color: rgba(0,159,227,.45);
    box-shadow: 0 16px 48px rgba(33,59,138,.35);
    color: #fff;
}

.cp-price-card.cp-price-featured:hover {
    box-shadow: 0 24px 60px rgba(33,59,138,.5);
    transform: translateY(-6px);
}

/* Badge "Più scelto" */
.cp-price-badge {
    position: absolute;
    top: -6px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--cyan);
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: 5px 18px;
    border-radius: var(--radius-pill);
    box-shadow: 0 4px 14px rgba(0,159,227,.4);
    white-space: nowrap;
    z-index: 1;
}

/* Nome piano */
.cp-price-name {
    font-family: var(--font-heading);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--text-mid);
    margin-bottom: 14px;
}

.cp-price-featured .cp-price-name { color: rgba(255,255,255,.65); }

/* Prezzo */
.cp-price-amount {
    display: flex;
    align-items: flex-start;
    gap: 4px;
    line-height: 1;
    margin-bottom: 4px;
}

.cp-price-currency {
    font-family: var(--font-heading);
    font-size: 1.4rem;
    font-weight: 700;
    margin-top: 8px;
    color: var(--navy);
}

.cp-price-featured .cp-price-currency { color: #fff; }

.cp-price-value {
    font-family: var(--font-heading);
    font-size: 3.2rem;
    font-weight: 800;
    letter-spacing: -0.04em;
    color: var(--navy);
    line-height: 1;
}

.cp-price-featured .cp-price-value { color: #fff; }

.cp-price-suffix {
    font-size: .78rem;
    font-weight: 600;
    color: var(--text-mid);
    margin-top: 10px;
    align-self: flex-start;
}

.cp-price-featured .cp-price-suffix { color: rgba(255,255,255,.55); }

.cp-price-period {
    font-size: .85rem;
    color: var(--text-mid);
    margin-bottom: 20px;
}

.cp-price-featured .cp-price-period { color: rgba(255,255,255,.55); }

/* Setup fee */
.cp-price-setup {
    font-size: .82rem;
    color: var(--text-mid);
    margin: 4px 0 20px 0;
    display: flex;
    align-items: center;
    gap: 3px;
}

.cp-price-setup-plus { font-size: 1.6rem; font-weight: 700; color: var(--text-mid); line-height: 1; margin-right: 2px; }
.cp-price-setup .cp-price-currency { font-size: 1rem; margin-top: 3px; }
.cp-price-setup .cp-price-value    { font-size: 2.2rem; font-weight: 700; font-family: var(--font-heading); letter-spacing: -.03em; color: var(--navy); }
.cp-price-setup .cp-price-suffix   { font-size: .72rem; color: var(--text-mid); }
.cp-price-card:has(.cp-price-setup) .cp-price-period {
    margin: 0px;
}
.cp-price-featured .cp-price-setup                   { color: rgba(255,255,255,.55); }
.cp-price-featured .cp-price-setup-plus              { color: rgba(255,255,255,.55); }
.cp-price-featured .cp-price-setup .cp-price-currency,
.cp-price-featured .cp-price-setup .cp-price-value  { color: #fff; }
.cp-price-featured .cp-price-setup .cp-price-suffix { color: rgba(255,255,255,.45); }

/* Divisore */
.cp-price-divider {
    border: none;
    border-top: 1px solid rgba(33,59,138,.1);
    margin: 0 0 16px;
}

.cp-price-featured .cp-price-divider { border-color: rgba(255,255,255,.15); }

/* Descrizione */
.cp-price-desc {
    font-size: .875rem;
    color: var(--text-mid);
    line-height: 1.55;
    margin: 0 0 24px;
    flex: 1;
}

.cp-price-featured .cp-price-desc { color: rgba(255,255,255); }

/* Pulsante aggiungi */
.cp-price-cta {
    width: 100%;
    justify-content: center;
    margin-top: auto;
}

.cp-price-featured .cp-price-cta {
    background: rgba(255,255,255,.15) !important;
    border: 1.5px solid rgba(255,255,255,.4) !important;
    color: #fff !important;
    box-shadow: none !important;
}

.cp-price-featured .cp-price-cta:hover {
    background: var(--cyan) !important;
    border-color: var(--cyan) !important;
    box-shadow: 0 8px 24px rgba(0,159,227,.4) !important;
}

.cp-price-featured .cp-price-cta.cp-added {
    background: var(--success) !important;
    border-color: var(--success) !important;
}

/* Nasconde le card filtrate dalla ricerca */
.cp-price-card.cp-hidden { display: none; }

.cp-no-products { color: var(--text-mid); font-style: italic; }

/* ============================================================
   CHECKOUT INLINE
   ============================================================ */

.cp-checkout-section {
    border-top: 1px solid rgba(33,59,138,.1);
    padding-top: 40px;
    margin-top: 4px;
}

.cp-checkout-wrap.cp-checkout-collapsed { display: none; }

.cp-mini-cart {
    background: var(--white);
    border: 1px solid rgba(33,59,138,.1);
    border-radius: var(--radius-lg);
    padding: 24px;
    margin-bottom: 24px;
    min-height: 64px;
    box-shadow: var(--shadow-sm);
}

.cp-mini-cart-list { list-style: none; margin: 0; padding: 0; }

.cp-mini-cart-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 0;
    border-bottom: 1px solid rgba(33,59,138,.08);
}

.cp-mini-cart-item:last-child { border-bottom: none; }

.cp-item-name     { flex: 1; font-size: .875rem; font-weight: 500; color: var(--text); }
.cp-item-qty      { color: var(--text-mid); font-size: .8rem; margin-left: 4px; }
.cp-item-subtotal { font-weight: 700; font-size: .9rem; color: var(--navy); white-space: nowrap; }

.cp-remove-item {
    background: none;
    border: 1px solid rgba(33, 59, 138, .15);
    border-radius: 100px;
    min-width: 26px;
    height: 26px;
    cursor: pointer;
    font-size: 1rem;
    color: var(--text-mid);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transition), color var(--transition), border-color var(--transition);
    flex-shrink: 0;
    line-height: 1;
    padding: 7px;
}

.cp-remove-item:hover {
    background: var(--danger-bg);
    color: var(--danger);
    border-color: var(--danger);
}

.cp-cart-total-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid rgba(33,59,138,.08);
    font-size: .95rem;
    font-weight: 600;
    color: var(--text);
}

.cp-cart-total {
    font-family: var(--font-heading);
    color: var(--navy);
    font-size: 1.15rem;
    font-weight: 800;
}

.cp-cart-empty {
    color: var(--text-mid);
    font-style: italic;
    text-align: center;
    padding: 12px 0;
    margin: 0;
    font-size: .875rem;
}

/* Checkout wrap */
.cp-checkout-wrap {
    background: var(--white);
    border: 1px solid rgba(33,59,138,.1);
    border-radius: var(--radius-lg);
    padding: 24px;
    box-shadow: var(--shadow-sm);
}

.cp-checkout-wrap h3 {
    font-size: 1.15rem;
    margin: 0 0 24px;
}

.cp-checkout-empty { color: var(--text-mid); font-style: italic; font-size: .875rem; }

/* Alert fatturazione mancante */
/* ============================================================
   BACK LINK
   ============================================================ */

.cp-back-link { margin-bottom: 24px; }
.cp-back-link a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: .875rem;
    font-weight: 500;
    color: var(--text-mid);
    text-decoration: none;
    transition: color var(--transition);
}
.cp-back-link a:hover { color: var(--cyan); }

/* ============================================================
   DETTAGLIO ABBONAMENTO
   ============================================================ */

.cp-abbo-overview { margin-bottom: 24px; }

.cp-abbo-overview-row {
    display: flex;
    flex-wrap: wrap;
    gap: 28px 40px;
}

.cp-abbo-overview-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 120px;
}

.cp-trial-banner {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin-top: 10px;
    padding: 8px 16px;
    border-radius: var(--radius-pill);
    background: var(--warning-bg);
    color: #92400e;
    font-size: .875rem;
    font-weight: 600;
}

.cp-abbo-actions {
    margin-top: 24px;
    padding-top: 20px;
    border-top: 1px solid rgba(33,59,138,.08);
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

/* Pagina aggiungi metodo di pagamento */
.cp-add-payment-card {
    max-width: 600px;
}

/* Sovrascrive stili WooCommerce nel contesto portale */
.cp-add-payment-card .woocommerce-SavedPaymentMethods-saveNew,
.cp-add-payment-card #add_payment_method #payment {
    border: none;
    padding: 0;
    background: none;
}

.cp-add-payment-card #add_payment_method #payment ul.payment_methods {
    padding: 0;
    list-style: none;
    margin: 0 0 20px;
}

.cp-add-payment-card #add_payment_method #payment .payment_box {
    background: var(--bg-soft);
    border-radius: var(--radius-md);
    padding: 16px;
    margin: 10px 0 0;
}

.cp-add-payment-card #add_payment_method #payment #place_order,
.cp-add-payment-card #add_payment_method .button[type="submit"] {
    background: var(--navy);
    color: #fff;
    border: none;
    border-radius: var(--radius-pill);
    padding: 12px 28px;
    font-size: .9rem;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--transition);
    margin-top: 16px;
}

.cp-add-payment-card #add_payment_method #payment #place_order:hover,
.cp-add-payment-card #add_payment_method .button[type="submit"]:hover {
    background: var(--navy-deep);
}

.cp-abbo-label {
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--text-mid);
}

/* ============================================================
   CONFERMA ORDINE
   ============================================================ */

.cp-conferma-hero {
    text-align: center;
    padding: 48px 0 32px;
}

.cp-conferma-icon {
    width: 72px; height: 72px;
    border-radius: 50%;
    background: var(--success-bg);
    color: var(--success);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}

.cp-conferma-hero h2 { font-size: 2rem; margin-bottom: 8px; }

.cp-conferma-sub { color: var(--text-mid); font-size: 1rem; margin: 0; }

.cp-conferma-card {
    background: var(--white);
    border: 1px solid rgba(33,59,138,.1);
    border-radius: var(--radius-lg);
    padding: 32px;
    box-shadow: var(--shadow-sm);
    max-width: 680px;
    margin: 0 auto 24px;
}

.cp-conferma-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .9rem;
    margin-top: 16px;
}

.cp-conferma-table th {
    text-align: left;
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--text-mid);
    border-bottom: 1px solid rgba(33,59,138,.1);
    padding: 0 8px 10px;
}

.cp-conferma-table td {
    padding: 12px 8px;
    border-bottom: 1px solid rgba(33,59,138,.06);
}

.cp-conferma-table .cp-col-qty,
.cp-conferma-table .cp-col-total { text-align: right; }

.cp-conferma-total-row td {
    font-weight: 700;
    border-top: 2px solid rgba(33,59,138,.12);
    border-bottom: none;
    padding-top: 16px;
    color: var(--navy);
}

.cp-conferma-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 20px;
    font-size: .82rem;
    color: var(--text-mid);
}

.cp-conferma-actions {
    display: flex;
    justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
    padding-bottom: 48px;
}

/* ============================================================
   TERMINI E CONDIZIONI — checkout
   ============================================================ */

.cp-tc-section { margin-top: 28px; }

.cp-tc-preview {
    max-height: 140px;
    overflow-y: auto;
    border: 1px solid rgba(33,59,138,.14);
    border-radius: var(--radius-sm);
    padding: 14px 16px;
    font-size: .83rem;
    line-height: 1.6;
    color: var(--text-mid);
    background: var(--bg-soft);
    margin-bottom: 10px;
}

.cp-tc-preview p:last-child { margin-bottom: 0; }

.cp-tc-read-more {
    background: none;
    border: none;
    padding: 0;
    color: var(--cyan);
    font-size: .82rem;
    font-weight: 600;
    cursor: pointer;
    text-decoration: underline;
    margin-bottom: 14px;
    display: block;
}

.cp-tc-accept {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: .875rem;
    cursor: pointer;
    line-height: 1.4;
}

.cp-tc-accept input[type="checkbox"] {
    margin-top: 2px;
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    cursor: pointer;
}

/* Modal */
.cp-tc-modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.cp-tc-modal[hidden] { display: none; }

.cp-tc-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10,10,26,.55);
    backdrop-filter: blur(4px);
}

.cp-tc-modal-inner {
    position: relative;
    background: var(--white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    width: 100%;
    max-width: 680px;
    max-height: 85vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.cp-tc-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px 16px;
    border-bottom: 1px solid rgba(33,59,138,.1);
    flex-shrink: 0;
}

.cp-tc-modal-header h3 { margin: 0; font-size: 1.05rem; }

.cp-tc-modal-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    line-height: 1;
    color: var(--text-mid);
    cursor: pointer;
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    transition: background var(--transition);
}

.cp-tc-modal-close:hover { background: var(--bg-soft); }

.cp-tc-modal-body {
    overflow-y: auto;
    padding: 20px 24px 28px;
    font-size: .9rem;
    line-height: 1.7;
    color: var(--text);
}

/* T&C archiviati nella pagina abbonamento */
.cp-tc-accepted-meta {
    font-size: .83rem;
    color: var(--text-mid);
    margin: 0 0 14px;
}

.cp-tc-archived {
    max-height: 260px;
    overflow-y: auto;
    border: 1px solid rgba(33,59,138,.1);
    border-radius: var(--radius-sm);
    padding: 16px;
    font-size: .85rem;
    line-height: 1.65;
    color: var(--text-soft);
    background: var(--bg-soft);
}

.cp-tc-archived p:last-child { margin-bottom: 0; }

/* ============================================================
   BILLING ALERT
   ============================================================ */

.cp-billing-alert {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 32px;
}

/* ── Layout a due colonne: sinistra campi, destra riepilogo ── */
@media (min-width: 768px) {
    .cp-checkout-wrap .woocommerce-checkout {
        display: grid;
        grid-template-columns: 3fr 2fr;
        grid-template-rows: auto 1fr;
        gap: 0 32px;
        align-items: start;
    }

    /* min-width: 0 impedisce agli item di sfondare la colonna */
    .cp-checkout-wrap .cp-checkout-custom-box,
    .cp-checkout-wrap #order_review_heading,
    .cp-checkout-wrap #order_review {
        min-width: 0;
    }

    /* Attribution inputs: non partecipano al grid */
    .cp-checkout-wrap wc-order-attribution-inputs {
        display: none !important;
    }

    /* Sinistra riga 1: billing */
    .cp-checkout-wrap #customer_details {
        grid-column: 1;
        grid-row: 1;
    }

    /* Sinistra riga 2: campi custom (consulente rif + categoria + T&C) */
    .cp-checkout-wrap .cp-checkout-custom-box {
        grid-column: 1;
        grid-row: 2;
    }

    /* Destra: heading e review occupano entrambe le righe (1/3),
       così partono dall'alto della griglia indipendentemente dall'altezza
       della colonna sinistra. Il review ha un margin-top pari all'altezza
       approssimativa dell'heading per non sovrapporsi. */
    .cp-checkout-wrap #order_review_heading {
        grid-column: 2;
        grid-row: 1 / 3;
        align-self: start;
        margin: 0;
        position: sticky;
        top: 24px;
        z-index: 3;
        padding-bottom: 12px;
    }

    .cp-checkout-wrap #order_review {
        grid-column: 2;
        grid-row: 1 / 3;
        align-self: start;
        margin-top: 50px; /* spazio per l'heading sticky (h3 ~26px + padding 12px + margine 12px) */
        position: sticky;
        top: 74px; /* 24px (top heading) + ~50px (altezza heading + padding) */
    }
}

@media (max-width: 767px) {
    .cp-checkout-custom-box {
        margin-bottom: 40px;
    }
}
.cp-cat-fields {
    background: var(--bg-soft);
    border: 1.5px solid rgba(33,59,138,.1);
    border-radius: var(--radius-md);
    padding: 24px 28px;
    margin-top: 30px;
}
#cp-checkout-wrap .cp-cat-fields .form-row :is(input, textarea) {
    background-color: #fff !important;
}
.cp-checkout-custom-title {
    font-family: var(--font-heading);
    font-weight: 700;
    color: var(--navy);
    margin: 0 0 20px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(33,59,138,.1);
}

div#cp-checkout-wrap .woocommerce .col-1 {
    width: 100%;
}
div#cp-checkout-wrap .woocommerce-billing-fields h3 {
    margin: 24px 0 12px 0 !important;
    float: left;
    width: 100%;
}
p#billing_codice_fiscale_aruba_fe_field {
    width: 100%;
}
p#billing_postcode_field, p#billing_city_field, p#billing_state_field {
    width: calc(100% / 3);
    float: left;
    clear: none;
}
p#billing_last_name_field, p#billing_first_name_field, p#billing_phone_field, p#billing_email_field {
    width: 50%;
    float: left;
    clear: none;
}
@media (max-width: 1024px) {
    p#billing_postcode_field, p#billing_city_field {
        width: 50%;
    }
    p#billing_state_field, p#billing_phone_field, p#billing_email_field {
        width: 100%;
    }
}

/* Consulente: nasconde l'intero blocco fatturazione (non necessario per lui) */
.cp-role-consulente .cp-checkout-wrap #customer_details { display: none !important; }

/* Customer: nasconde solo il tab "Spedizione" (col-2) e il campo paese ridondante */
.cp-role-customer .cp-checkout-wrap #customer_details .col-2,
.cp-role-customer .cp-checkout-wrap #customer_details #billing_country_field { display: none !important; }

/* Per il consulente (billing nascosto), la custom-box sale in riga 1 */
@media (min-width: 768px) {
    .cp-role-consulente .cp-checkout-wrap .cp-checkout-custom-box {
        grid-row: 1;
    }
}

/* Override WooCommerce checkout */
.cp-checkout-wrap .woocommerce-checkout { font-family: var(--font-body); }

.cp-checkout-wrap .woocommerce-checkout label { color: var(--text-mid) !important; font-size: .82rem !important; font-weight: 600 !important; }

.cp-checkout-wrap .woocommerce-checkout input:not([type="checkbox"]):not([type="radio"]),
.cp-checkout-wrap .woocommerce-checkout select,
.cp-checkout-wrap .woocommerce-checkout textarea {
    border: 1.5px solid rgba(33,59,138,.15) !important;
    border-radius: var(--radius-md) !important;
    padding: 10px 14px !important;
    font-family: var(--font-body) !important;
    font-size: 16px !important;
    background: var(--bg-soft) !important;
    color: var(--text) !important;
    transition: border-color var(--transition), box-shadow var(--transition) !important;
}
p.form-row-wide {
    margin: 0px;
}

.cp-checkout-wrap .woocommerce-checkout input:focus,
.cp-checkout-wrap .woocommerce-checkout select:focus,
.cp-checkout-wrap .woocommerce-checkout textarea:focus {
    outline: none !important;
    border-color: var(--cyan) !important;
    box-shadow: 0 0 0 3px rgba(0,159,227,.15) !important;
}

.cp-checkout-wrap #place_order {
    background: var(--cyan) !important;
    border: none !important;
    border-radius: var(--radius-pill) !important;
    color: #fff !important;
    font-family: var(--font-body) !important;
    font-size: .95rem !important;
    font-weight: 700 !important;
    padding: 14px 32px !important;
    cursor: pointer !important;
    box-shadow: 0 8px 24px rgba(0,159,227,.35) !important;
    transition: box-shadow .25s, transform .25s !important;
}

.cp-checkout-wrap #place_order:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 14px 40px rgba(0,159,227,.5) !important;
}

/* ── Tabella riepilogo ordine ── */
.cp-checkout-wrap table.woocommerce-checkout-review-order-table {
    width: 100%;
    table-layout: fixed;
    border-collapse: collapse;
    font-family: var(--font-body);
    font-size: .88rem;
    margin-bottom: 0;
}

.cp-checkout-wrap table.woocommerce-checkout-review-order-table .product-name {
    width: 65%;
    word-break: break-word;
}

.cp-checkout-wrap table.woocommerce-checkout-review-order-table .product-total {
    width: 35%;
}

.cp-checkout-wrap table.woocommerce-checkout-review-order-table thead th {
    color: var(--text-mid);
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    border-bottom: 1.5px solid rgba(33,59,138,.12);
    padding: 0 0 10px;
}

.cp-checkout-wrap table.woocommerce-checkout-review-order-table tbody td {
    padding: 10px 0;
    border-bottom: 1px solid rgba(33,59,138,.07);
    color: var(--text);
    vertical-align: middle;
}

.cp-checkout-wrap table.woocommerce-checkout-review-order-table tfoot th,
.cp-checkout-wrap table.woocommerce-checkout-review-order-table tfoot td {
    padding: 8px 0;
    color: var(--text-mid);
    font-size: .85rem;
}

.cp-checkout-wrap table.woocommerce-checkout-review-order-table .order-total th,
.cp-checkout-wrap table.woocommerce-checkout-review-order-table .order-total td {
    color: var(--navy);
    font-weight: 700;
    font-size: .95rem;
    border-top: 1.5px solid rgba(33,59,138,.12);
    padding-top: 12px;
}

.cp-checkout-wrap table.woocommerce-checkout-review-order-table .recurring-totals th {
    color: var(--text-mid);
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    padding-top: 16px;
    border-top: 1.5px solid rgba(33,59,138,.08);
}

.cp-checkout-wrap table.woocommerce-checkout-review-order-table .product-total {
    text-align: right;
}

/* Subscription price inline */
.cp-checkout-wrap .subscription-details {
    display: block;
    font-size: .78rem;
    color: var(--text-mid);
    margin-top: 2px;
}

/* Box #order_review come card */
.cp-checkout-wrap #order_review {
    background: var(--white);
    border: 1px solid rgba(33,59,138,.1);
    border-radius: var(--radius-lg);
    padding: 24px;
    box-shadow: var(--shadow-sm);
}

/* Titolo "Il tuo ordine" */
.cp-checkout-wrap #order_review_heading {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--navy);
}

/* Payment box */
.cp-checkout-wrap #payment {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
}

.cp-checkout-wrap #payment .woocommerce-PaymentMethods,
.cp-checkout-wrap #payment ul.payment_methods {
    list-style: none !important;
    padding: 0 !important;
    margin: 16px 0 0 !important;
    border: none !important;
    background: transparent !important;
}

.cp-checkout-wrap #payment .wc_payment_method > label {
    font-size: .78rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .06em !important;
    color: var(--text-mid) !important;
    margin-bottom: 10px !important;
    display: block !important;
}

.cp-checkout-wrap #payment .payment_box {
    background: var(--bg-soft) !important;
    border: 1px solid rgba(33,59,138,.1) !important;
    border-radius: var(--radius-md) !important;
    padding: 16px !important;
    margin: 0 !important;
}

.cp-checkout-wrap #payment .woocommerce-SavedPaymentMethods {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.cp-checkout-wrap #payment .woocommerce-SavedPaymentMethods-token,
.cp-checkout-wrap #payment .woocommerce-SavedPaymentMethods-new {
    padding: 7px 0 !important;
    font-size: .88rem !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.cp-checkout-wrap .woocommerce-privacy-policy-text {
    font-size: .78rem;
    color: var(--text-mid);
    margin: 16px 0 12px;
    line-height: 1.5;
}

.cp-checkout-wrap .form-row.place-order {
    padding: 0 !important;
    margin: 0 !important;
}

/* ============================================================
   ABBONAMENTI
   ============================================================ */

.cp-abbonamenti h2 { font-size: 1.4rem; margin: 0 0 22px; }

.cp-filter-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.cp-filter-label { font-size: .875rem; font-weight: 600; color: var(--text-mid); }

.cp-filter-select {
    padding: 8px 16px;
    border: 1.5px solid rgba(33,59,138,.15);
    border-radius: var(--radius-pill);
    font-family: var(--font-body);
    font-size: .875rem;
    background: var(--white);
    color: var(--text);
    cursor: pointer;
    outline: none;
    transition: border-color var(--transition);
    appearance: auto;
}

.cp-filter-select:focus { border-color: var(--cyan); }

.cp-table-wrap {
    overflow-x: auto;
    border-radius: var(--radius-lg);
    border: 1px solid rgba(33,59,138,.1);
    box-shadow: var(--shadow-sm);
}

.cp-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .875rem;
    background: var(--white);
}

.cp-table th,
.cp-table td {
    padding: 14px 18px;
    text-align: left;
    border-bottom: 1px solid rgba(33,59,138,.07);
    color: var(--text);
    white-space: nowrap;
}

.cp-table thead th {
    background: var(--bg-soft);
    font-weight: 700;
    color: var(--text-mid);
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.cp-table tbody tr:last-child td { border-bottom: none; }
.cp-table tbody tr:hover { background: var(--bg-soft); }
.cp-table .cp-sub-row.cp-hidden { display: none; }

/* Testo secondario nelle celle abbonamento */
.cp-sub-meta {
    display: block;
    font-size: .78rem;
    color: var(--text-mid);
    margin-top: 2px;
    line-height: 1.4;
}

.cp-sub-meta svg {
    vertical-align: middle;
    margin-right: 3px;
    flex-shrink: 0;
}

/* Colonne data */
.cp-date-cell {
    white-space: nowrap;
    font-size: .85rem;
}

.cp-date-expired {
    color: var(--danger, #b91c1c);
    font-weight: 600;
}

/* Tabella consulente: colonna referente un po' più larga */
.cp-sub-table-consulente th:nth-child(2),
.cp-sub-table-consulente td:nth-child(2) {
    min-width: 160px;
}

/* Badge stato */
.cp-status-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    border-radius: var(--radius-pill);
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
}

.cp-status-active    { background: var(--success-bg); color: #15803d; }
.cp-status-on-hold   { background: var(--warning-bg); color: #92400e; }
.cp-status-cancelled { background: var(--danger-bg);  color: #b91c1c; }
.cp-status-expired   { background: #f1f5f9;            color: var(--text-mid); }
.cp-status-pending   { background: #e8f5fd;            color: #0369a1; }
.cp-status-trial     { background: #f0e6ff;            color: #6b21a8; }

.cp-table-count { font-size: .82rem; color: var(--text-mid); margin-top: 12px; }

/* ── Tabella abbonamenti: layout mobile a card (no scroll orizzontale) ── */
@media (max-width: 768px) {

    .cp-table-wrap:has(.cp-sub-table) {
        overflow-x: visible;
        border: none;
        box-shadow: none;
        border-radius: 0;
        background: transparent;
    }

    .cp-sub-table,
    .cp-sub-table tbody {
        display: block;
        width: 100%;
    }

    .cp-sub-table thead { display: none; }

    /* Ogni riga = una card */
    .cp-sub-table tr {
        display: block;
        background: var(--white);
        border: 1px solid rgba(33,59,138,.10);
        border-radius: var(--radius-md);
        box-shadow: var(--shadow-sm);
        margin-bottom: 14px;
        overflow: hidden;
    }

    .cp-sub-table tr:hover { background: var(--white); }

    /* Header della card (nome prodotto / nome cliente) */
    .cp-sub-table td.cp-sub-card-title {
        display: block;
        background: rgba(33,59,138,.04);
        padding: 13px 16px;
        border-bottom: 1px solid rgba(33,59,138,.08);
        font-size: .95rem;
        white-space: normal;
    }

    .cp-sub-table td.cp-sub-card-title strong {
        display: block;
        color: var(--navy);
        font-size: 1rem;
    }

    /* Righe dati: label a sinistra, valore a destra */
    .cp-sub-table td:not(.cp-sub-card-title):not(.cp-sub-actions) {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 10px 16px;
        border-bottom: 1px solid rgba(33,59,138,.04);
        font-size: .88rem;
        text-align: right;
        white-space: normal;
        gap: 12px;
    }

    .cp-sub-table td[data-label]::before {
        content: attr(data-label);
        font-size: .72rem;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: .05em;
        color: var(--text-mid);
        flex-shrink: 0;
        text-align: left;
    }

    /* Cella azioni: bottone full-width */
    .cp-sub-table td.cp-sub-actions {
        display: block;
        padding: 12px 16px;
        border-top: 1px solid rgba(33,59,138,.06);
    }

    .cp-sub-table td.cp-sub-actions .cp-btn {
        width: 100%;
        justify-content: center;
    }

    table.cp-table.cp-sub-table.cp-sub-table-consulente {
        background: none;
    }

    /* Colonna referente: testo a sinistra (contiene nome + righe meta) */
    .cp-sub-table-consulente td[data-label="Referente"] {
        align-items: flex-start;
    }

    .cp-sub-table td .cp-status-badge {
        white-space: nowrap;
    }

    /* Nascondi righe filtrate */
    .cp-sub-table tr.cp-hidden { display: none !important; }
}

/* ============================================================
   ACCOUNT — Tab navigation (pillole come il sito)
   ============================================================ */

.cp-account h2 { font-size: 1.4rem; margin: 0 0 22px; }

.cp-account-tabs {
    display: flex;
    gap: 6px;
    margin-bottom: 24px;
    background: var(--white);
    border: 1px solid rgba(33,59,138,.1);
    border-radius: var(--radius-pill);
    padding: 6px;
    box-shadow: var(--shadow-sm);
    flex-wrap: wrap;
    width: fit-content;
}

.cp-account-tab {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 10px 20px;
    border: none;
    border-radius: var(--radius-pill);
    background: transparent;
    color: var(--text-mid);
    font-family: var(--font-body);
    font-size: .86rem;
    font-weight: 500;
    cursor: pointer;
    transition: background var(--transition), color var(--transition), box-shadow var(--transition);
    white-space: nowrap;
}

.cp-account-tab:hover { background: var(--bg-soft); color: var(--navy); }

.cp-account-tab.cp-account-tab-active {
    background: var(--cyan);
    color: #fff;
    font-weight: 600;
    box-shadow: 0 0 0 1px rgba(255,255,255,.15) inset, 0 6px 18px rgba(0,159,227,.35);
}

@media (max-width: 600px) {
    .cp-account-tabs   { border-radius: var(--radius-lg); width: 100%; }
    .cp-account-tab    { padding: 8px 14px; font-size: .78rem; }
}

/* ============================================================
   ACCOUNT — Panel e Card
   ============================================================ */

.cp-tab-panel  { display: block; }
.cp-tab-hidden { display: none; }

.cp-account-card {
    background: var(--white);
    border: 1px solid rgba(33,59,138,.1);
    border-radius: var(--radius-lg);
    padding: 36px;
    box-shadow: var(--shadow-sm);
}

.cp-account-card:has(table.cp-conferma-table) {
    margin-bottom: 24px;
}

.cp-account-card-title {
    margin: 0 0 28px;
}

/* ============================================================
   ACCOUNT — Form
   ============================================================ */

.cp-form { max-width: 680px; }

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

@media (max-width: 560px) { .cp-form-row-2 { grid-template-columns: 1fr; } }

.cp-form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 14px;
}

.cp-form-group-full { grid-column: 1 / -1; }

.cp-form-group label {
    font-size: .78rem;
    font-weight: 700;
    color: var(--text-mid);
    letter-spacing: .08em;
    text-transform: uppercase;
}

.cp-required { color: var(--danger); margin-left: 2px; }

.cp-form-group input[type="text"],
.cp-form-group input[type="email"],
.cp-form-group input[type="tel"],
.cp-form-group input[type="password"],
.cp-form-group select,
select#billing_state,
input#billing_state,
input#billing_country {
    padding: 11px 16px;
    border: 1.5px solid rgba(33,59,138,.15);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: .9rem;
    color: var(--text);
    background: var(--bg-soft);
    transition: border-color var(--transition), box-shadow var(--transition);
    width: 100%;
    outline: none;
    appearance: auto;
}

input#billing_need_invoice_aruba_fe {
    width: 13px !important;
}

.cp-form-group input:focus,
.cp-form-group select:focus {
    border-color: var(--cyan);
    box-shadow: 0 0 0 3px rgba(0,159,227,.15);
    background: var(--white);
}

.cp-form-hint {
    font-size: .82rem;
    color: var(--text-mid);
    margin: 0 0 14px;
    font-style: italic;
}

.cp-account-divider {
    display: flex;
    align-items: center;
    gap: 14px;
    margin: 28px 0 14px;
    color: var(--text-mid);
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .1em;
}

.cp-account-divider::before,
.cp-account-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(33,59,138,.1);
}

.cp-form-footer {
    margin-top: 28px;
    padding-top: 22px;
    border-top: 1px solid rgba(33,59,138,.08);
    display: flex;
    gap: 12px;
    align-items: center;
}

/* ============================================================
   ACCOUNT — Metodi di pagamento
   ============================================================ */

.cp-payment-list { display: flex; flex-direction: column; gap: 12px; margin-bottom: 24px; }

.cp-payment-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 18px 22px;
    border: 1px solid rgba(33,59,138,.1);
    border-radius: var(--radius-md);
    background: var(--bg-soft);
    transition: border-color var(--transition), box-shadow var(--transition);
}

.cp-payment-item:hover { border-color: rgba(0,159,227,.3); box-shadow: var(--shadow-sm); }

.cp-payment-item.cp-payment-default {
    border-color: rgba(0,159,227,.45);
    background: #e8f5fd;
}

.cp-payment-icon { color: var(--cyan); flex-shrink: 0; }

.cp-payment-info {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

.cp-payment-brand  { font-family: var(--font-heading); font-weight: 700; font-size: .95rem; color: var(--navy); }
.cp-payment-number,
.cp-payment-expiry { font-size: .85rem; color: var(--text-mid); font-family: monospace; }

.cp-payment-actions { flex-shrink: 0; display: flex; align-items: center; gap: 8px; }
.cp-default-badge { align-self: center; }

.cp-payment-footer {
    padding-top: 22px;
    border-top: 1px solid rgba(33,59,138,.08);
}

/* ============================================================
   BARRE PROGRESSO
   ============================================================ */

.cp-progress-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 16px; }

.cp-progress-header {
    display: flex;
    justify-content: space-between;
    margin-bottom: 6px;
    font-size: .85rem;
    font-weight: 600;
    color: var(--text);
}

.cp-progress-track { height: 6px; background: rgba(33,59,138,.1); border-radius: 3px; overflow: hidden; }
.cp-progress-fill  { height: 100%; background: var(--cyan); border-radius: 3px; transition: width .6s ease; }

/* ============================================================
   LOADING / SPINNER
   ============================================================ */

.cp-loading { opacity: .55; pointer-events: none; }

@keyframes cp-spin { to { transform: rotate(360deg); } }

.cp-spinner {
    display: inline-block;
    width: 16px; height: 16px;
    border: 2px solid rgba(255,255,255,.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: cp-spin .65s linear infinite;
    vertical-align: middle;
}

/* ============================================================
   SCROLLBAR sottile
   ============================================================ */

.cp-table-wrap::-webkit-scrollbar       { height: 5px; }
.cp-table-wrap::-webkit-scrollbar-track { background: var(--bg-soft); }
.cp-table-wrap::-webkit-scrollbar-thumb { background: rgba(33,59,138,.2); border-radius: 3px; }

/* ============================================================
   PAGINA DI LOGIN
   ============================================================ */

.cp-login-page {
    display: grid;
    grid-template-columns: 45% 55%;
    min-height: 100vh;
    font-family: var(--font-body);
}

/* ── Pannello sinistro: brand ── */
.cp-login-brand-panel {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 60px 48px;
    position: relative;
    overflow: hidden;
}

.cp-login-brand-panel:before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(1000px 600px at 20% 10%, rgba(0, 159, 227, .45), transparent 60%), radial-gradient(800px 500px at 85% 80%, rgb(30 44 87), transparent 60%), linear-gradient(180deg, #0a0a1a 0%, #111a3d 55%, #0a0a1a 100%);
    z-index: -2;
}

.page-hero-grid {
    position: absolute;
    background-image: linear-gradient(to right, rgba(255, 255, 255, 0.04) 1px, transparent 1px), linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px);
    background-size: 60px 60px;
    mask-image: radial-gradient(70% 60%, black, transparent);
    z-index: -1;
    inset: 0px;
}

.cp-login-brand-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 28px;
    text-align: center;
    position: relative;
    z-index: 1;
}

.cp-login-logo {
    max-width: 200px;
    width: 100%;
    height: auto;
}

.cp-login-mascot {
    max-width: 260px;
    width: 100%;
    height: auto;
}

.cp-login-tagline {
    color: rgba(255,255,255,.75);
    font-size: .95rem;
    line-height: 1.6;
    max-width: 280px;
    margin: 0;
}

/* ── Pannello destro: form ── */
.cp-login-form-panel {
    background: var(--white);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 60px 48px;
}

.cp-login-form-inner {
    width: 100%;
    max-width: 420px;
}

.cp-login-title {
    font-family: var(--font-heading);
    font-size: 2rem;
    font-weight: 800;
    color: var(--navy);
    margin: 0 0 8px;
    letter-spacing: -0.03em;
    line-height: 1.1;
}

.cp-login-subtitle {
    color: var(--text-mid);
    font-size: .95rem;
    margin: 0 0 32px;
}

/* Input password con toggle */
.cp-password-wrap {
    position: relative;
    display: flex;
    align-items: center;
}

.cp-password-wrap input {
    padding-right: 48px !important;
}

.cp-toggle-pass {
    position: absolute;
    right: 14px;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text-mid);
    padding: 0;
    display: flex;
    align-items: center;
    transition: color var(--transition);
    line-height: 1;
}

.cp-toggle-pass:hover { color: var(--navy); }

.cp-eye-icon { display: block; }

/* Login options row */
.cp-login-options {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: 4px 0 24px;
    flex-wrap: wrap;
}

.cp-check-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-size: .875rem;
    color: var(--text-mid);
    user-select: none;
}

.cp-check-label input[type="checkbox"] {
    accent-color: var(--cyan);
    width: 16px;
    height: 16px;
    cursor: pointer;
}

/* Link-style button */
.cp-link-btn {
    background: none;
    border: none;
    padding: 0;
    font-family: var(--font-body);
    font-size: .875rem;
    color: var(--cyan);
    cursor: pointer;
    text-decoration: none;
    transition: color var(--transition);
    font-weight: 500;
}

.cp-link-btn:hover { color: var(--navy); text-decoration: underline; }

/* Full-width button */
.cp-btn-block {
    width: 100%;
    justify-content: center;
}

/* Sezione recupero password */
.cp-forgot-section { margin-top: 4px; }

.cp-forgot-actions {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 4px;
}

/* ── Responsive ── */
@media (max-width: 900px) {
    .cp-login-page { grid-template-columns: 1fr; }

    .cp-login-brand-panel {
        padding: 48px 32px 36px;
        min-height: 0;
    }

    .cp-login-mascot { max-width: 160px; }
    .cp-login-logo   { max-width: 160px; }

    .cp-login-brand-inner { gap: 16px; flex-direction: row; flex-wrap: wrap; justify-content: center; }
    .cp-login-tagline { display: none; }

    .cp-login-form-panel { padding: 48px 24px 60px; }
    .cp-login-title { font-size: 1.6rem; }
}

/* ── Login tabs (Accedi / Registrati) ── */
.cp-login-tabs {
    display: flex;
    gap: 4px;
    background: rgba(33,59,138,.06);
    border-radius: var(--radius-pill);
    padding: 4px;
    margin-bottom: 28px;
}

.cp-login-tab {
    flex: 1;
    padding: 9px 0;
    font-family: var(--font-body);
    font-size: .88rem;
    font-weight: 600;
    color: var(--text-mid);
    background: none;
    border: none;
    border-radius: var(--radius-pill);
    cursor: pointer;
    transition: background var(--transition), color var(--transition), box-shadow var(--transition);
}

.cp-login-tab.cp-login-tab-active {
    background: var(--white);
    color: var(--navy);
    box-shadow: 0 1px 6px rgba(33,59,138,.12);
}

/* ── Stats grid varianti ── */
.cp-stats-grid-2 { grid-template-columns: repeat(2, 1fr); }
.cp-stats-grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1024px) { .cp-stats-grid-4 { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) {
    .cp-stats-grid-2,
    .cp-stats-grid-4 { grid-template-columns: 1fr; }
}

/* Stat value più piccolo (per prezzi) */
.cp-stat-value-sm { font-size: 1.5rem !important; }

/* ============================================================
   WC NATIVE PAGES — override stile per order-pay e my-account
   ============================================================ */

/* Body background */
body, .woocommerce-page body,
body.woocommerce-page,
body.woocommerce-account,
body.woocommerce-order-pay {
    background: var(--bg-soft) !important;
    font-family: var(--font-body) !important;
    color: var(--text) !important;
    -webkit-font-smoothing: antialiased;
}

/* Contenitore principale */
.woocommerce-order-pay .entry-content,
.woocommerce-account .entry-content,
.woocommerce-order-pay .woocommerce,
.woocommerce-account .woocommerce {
    max-width: 680px;
    margin: 40px auto;
    padding: 0 24px;
}

/* Card wrapper sui form */
.woocommerce-order-pay #order_review,
.woocommerce-account .woocommerce-MyAccount-content {
    background: var(--white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    border: 1px solid rgba(33,59,138,.07);
    padding: 32px;
}

/* Headings */
.woocommerce-order-pay h1,
.woocommerce-order-pay h2,
.woocommerce-order-pay h3,
.woocommerce-account h1,
.woocommerce-account h2,
.woocommerce-account h3 {
    font-family: var(--font-heading) !important;
    color: var(--navy) !important;
    letter-spacing: -0.02em;
    font-weight: 700;
}

/* Titolo pagina */
.woocommerce-order-pay .entry-title,
.woocommerce-account .entry-title {
    font-family: var(--font-heading) !important;
    color: var(--navy) !important;
    font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: 24px;
    letter-spacing: -0.02em;
}

/* Form fields */
.woocommerce-order-pay .input-text,
.woocommerce-order-pay select,
.woocommerce-account .input-text,
.woocommerce-account select {
    border: 1.5px solid rgba(33,59,138,.18) !important;
    border-radius: var(--radius-sm) !important;
    padding: 10px 14px !important;
    font-family: var(--font-body) !important;
    font-size: .9rem !important;
    color: var(--text) !important;
    background: var(--white) !important;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.woocommerce-order-pay .input-text:focus,
.woocommerce-account .input-text:focus {
    border-color: var(--cyan) !important;
    box-shadow: 0 0 0 3px rgba(0,159,227,.12) !important;
    outline: none !important;
}

/* Pulsante principale */
.woocommerce-order-pay #payment #place_order,
.woocommerce-order-pay .button.alt,
.woocommerce-account .button.alt,
.woocommerce-account .woocommerce-Button.button {
    background: var(--cyan) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--radius-pill) !important;
    padding: 13px 28px !important;
    font-family: var(--font-body) !important;
    font-size: .9rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    box-shadow: 0 8px 24px rgba(0,159,227,.35) !important;
    transition: transform .25s cubic-bezier(.2,.9,.3,1.2), box-shadow .25s !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
}

.woocommerce-order-pay #payment #place_order:hover,
.woocommerce-order-pay .button.alt:hover,
.woocommerce-account .button.alt:hover,
.woocommerce-account .woocommerce-Button.button:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 14px 40px rgba(0,159,227,.5) !important;
    color: #fff !important;
}

/* Pulsante secondario */
.woocommerce-account .button:not(.alt):not(.woocommerce-Button) {
    background: transparent !important;
    color: var(--navy) !important;
    border: 1.5px solid rgba(33,59,138,.22) !important;
    border-radius: var(--radius-pill) !important;
    padding: 11px 24px !important;
    font-family: var(--font-body) !important;
    font-size: .9rem !important;
    font-weight: 600 !important;
    transition: background var(--transition), color var(--transition) !important;
}

.woocommerce-account .button:not(.alt):not(.woocommerce-Button):hover {
    background: var(--navy) !important;
    color: #fff !important;
    border-color: var(--navy) !important;
}

/* Tabella ordine */
.woocommerce-order-pay table.shop_table,
.woocommerce-account table.shop_table {
    width: 100%;
    border-collapse: collapse;
    font-family: var(--font-body);
    font-size: .9rem;
    margin-bottom: 24px;
}

.woocommerce-order-pay table.shop_table th,
.woocommerce-account table.shop_table th {
    color: var(--text-mid);
    font-weight: 600;
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    border-bottom: 1.5px solid rgba(33,59,138,.1);
    padding: 10px 12px;
    text-align: left;
}

.woocommerce-order-pay table.shop_table td,
.woocommerce-account table.shop_table td {
    padding: 12px;
    border-bottom: 1px solid rgba(33,59,138,.06);
    color: var(--text);
    vertical-align: middle;
}

.woocommerce-order-pay table.shop_table tfoot td,
.woocommerce-order-pay table.shop_table tfoot th {
    font-weight: 700;
    color: var(--navy);
    border-top: 2px solid rgba(33,59,138,.12);
}

/* Payment box (Stripe element) */
.woocommerce-order-pay #payment,
.woocommerce-order-pay ul.payment_methods {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
}

.woocommerce-order-pay ul.payment_methods li {
    padding: 0 !important;
    list-style: none !important;
}

.woocommerce-order-pay .payment_box {
    background: var(--bg-soft) !important;
    border-radius: var(--radius-md) !important;
    border: 1px solid rgba(33,59,138,.1) !important;
    padding: 20px !important;
    margin: 12px 0 20px !important;
}

/* Notices */
.woocommerce-order-pay .woocommerce-error,
.woocommerce-order-pay .woocommerce-message,
.woocommerce-order-pay .woocommerce-info,
.woocommerce-account .woocommerce-error,
.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info {
    border-radius: var(--radius-md) !important;
    font-family: var(--font-body) !important;
    font-size: .9rem !important;
    padding: 14px 18px !important;
    border-left-width: 4px !important;
}

/* Nav account WC */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    margin: 0 0 24px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.woocommerce-account .woocommerce-MyAccount-navigation a {
    display: inline-block;
    padding: 8px 18px;
    border-radius: var(--radius-pill);
    font-size: .85rem;
    font-weight: 500;
    color: var(--text-mid);
    border: 1.5px solid rgba(33,59,138,.15);
    text-decoration: none !important;
    transition: background var(--transition), color var(--transition);
}

.woocommerce-account .woocommerce-MyAccount-navigation a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation .is-active a {
    background: var(--navy);
    color: #fff !important;
    border-color: var(--navy);
}

/* Links generici */
.woocommerce-order-pay a:not(.button),
.woocommerce-account a:not(.button) {
    color: var(--cyan);
    text-decoration: none;
}

.woocommerce-order-pay a:not(.button):hover,
.woocommerce-account a:not(.button):hover {
    color: var(--navy);
}

/* ============================================================
   DASHBOARD CONSULENTE — componenti avanzati
   ============================================================ */

/* Sub-label sotto il valore nella stat card */
.cp-stat-sub {
    font-size: .75rem;
    color: var(--text-mid);
    line-height: 1.3;
    margin-top: -4px;
}
.cp-stat-card.cp-stat-featured .cp-stat-sub {
    color: rgba(255,255,255,.6);
}

/* Card grafico */
.cp-chart-card {
    background: var(--white);
    border: 1px solid rgba(33,59,138,.1);
    border-radius: var(--radius-lg);
    padding: 28px 28px 24px;
    box-shadow: var(--shadow-sm);
    margin-bottom: 28px;
}
.cp-chart-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 20px;
}
.cp-chart-header h3 {
    margin: 0 0 4px;
}
.cp-chart-sub {
    font-size: .78rem;
    color: var(--text-mid);
    margin: 0;
}
.cp-chart-wrap {
    position: relative;
    height: 280px;
}
@media (max-width: 768px) {
    .cp-chart-wrap { height: 260px; }
}
@media (max-width: 480px) {
    .cp-chart-wrap { height: 240px; }
}

/* Grid sezioni inferiori */
.cp-dash-bottom-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 32px;
}
@media (max-width: 860px) {
    .cp-dash-bottom-grid { grid-template-columns: 1fr; }
}

/* Card sezione (rinnovi / top clienti) */
.cp-dash-section-card {
    background: var(--white);
    border: 1px solid rgba(33,59,138,.1);
    border-radius: var(--radius-lg);
    padding: 24px;
    box-shadow: var(--shadow-sm);
}

.cp-section-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .95rem;
    font-weight: 700;
    color: var(--navy);
    margin: 0 0 18px;
}
.cp-section-title svg { flex-shrink: 0; opacity: .7; }

.cp-section-badge {
    margin-left: auto;
    background: rgba(33,59,138,.08);
    color: var(--navy);
    font-size: .72rem;
    font-weight: 700;
    padding: 2px 9px;
    border-radius: var(--radius-pill);
}

.cp-empty-msg {
    color: var(--text-mid);
    font-size: .87rem;
    text-align: center;
    padding: 24px 0;
    margin: 0;
}

/* Lista rinnovi */
.cp-renew-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.cp-renew-item {
    display: flex;
    align-items: center;
    gap: 12px;
}
.cp-renew-avatar {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--cyan-soft), var(--navy));
    color: #fff;
    font-weight: 700;
    font-size: .9rem;
    display: flex;
    align-items: center;
    justify-content: center;
}
.cp-renew-info {
    flex: 1;
    min-width: 0;
}
.cp-renew-info strong {
    display: block;
    font-size: .88rem;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cp-renew-info span {
    display: block;
    font-size: .75rem;
    color: var(--text-mid);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cp-renew-date {
    flex-shrink: 0;
    font-size: .78rem;
    color: var(--text-mid);
    white-space: nowrap;
}
.cp-renew-amount {
    flex-shrink: 0;
    font-size: .88rem;
    font-weight: 700;
    color: var(--navy);
    white-space: nowrap;
}

/* Top clienti */
.cp-top-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
    counter-reset: top-rank;
}
.cp-top-item {
    display: flex;
    align-items: center;
    gap: 12px;
}
.cp-top-rank {
    flex-shrink: 0;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: rgba(33,59,138,.07);
    color: var(--navy);
    font-size: .78rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
}
.cp-top-info {
    flex: 1;
    min-width: 0;
}
.cp-top-info strong {
    display: block;
    font-size: .88rem;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 5px;
}
.cp-top-bar-wrap {
    height: 4px;
    background: rgba(33,59,138,.08);
    border-radius: 4px;
    overflow: hidden;
}
.cp-top-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--cyan), var(--navy));
    border-radius: 4px;
    transition: width .6s ease;
}
.cp-top-value {
    flex-shrink: 0;
    text-align: right;
}
.cp-top-value span {
    display: block;
    font-size: .88rem;
    font-weight: 700;
    color: var(--navy);
    white-space: nowrap;
}
.cp-top-value small {
    display: block;
    font-size: .72rem;
    color: var(--text-mid);
}

/* ============================================================
   PLAN SELECTOR — UI selezione piano abbonamento variabile
   ============================================================ */

.cp-plan-selector {
    margin-top: 14px;
}

.cp-plan-label {
    font-size: .75rem;
    font-weight: 700;
    color: var(--text-mid);
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: 10px;
}

.cp-price-card.cp-price-featured .cp-plan-label {
    color: rgba(255,255,255,.6);
}

.cp-plan-boxes {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* ── Single plan row ── */
.cp-plan-box {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: 0;
    padding: 0;
    background: #fff;
    border: 1.5px solid rgba(33,59,138,.13);
    border-radius: 10px;
    cursor: pointer;
    overflow: hidden;
    transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
    text-align: left;
    width: 100%;
}

.cp-plan-box:hover,
.cp-plan-box:focus-visible {
    border-color: var(--cyan);
    box-shadow: 0 2px 12px rgba(0,159,227,.18);
    transform: translateY(-1px);
    outline: none;
}

.cp-plan-box:active {
    transform: translateY(0);
    box-shadow: none;
}

.cp-price-card.cp-price-featured .cp-plan-box {
    background: rgba(255,255,255,.12);
    border-color: rgba(255,255,255,.22);
}

.cp-price-card.cp-price-featured .cp-plan-box:hover {
    background: rgba(255,255,255,.2);
    border-color: rgba(255,255,255,.55);
    box-shadow: 0 2px 12px rgba(0,0,0,.15);
}

/* Left: plan name + period */
.cp-plan-box-left {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 11px 14px;
    min-width: 0;
}

.cp-plan-name {
    font-weight: 700;
    font-size: .88rem;
    color: var(--navy);
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cp-plan-period {
    font-size: .72rem;
    font-weight: 500;
    color: var(--text-mid);
    line-height: 1.2;
}

.cp-price-card.cp-price-featured .cp-plan-name  { color: #fff; }
.cp-price-card.cp-price-featured .cp-plan-period { color: rgba(255,255,255,.65); }

/* Mid: price + setup fee */
.cp-plan-box-mid {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
    padding: 11px 14px 11px 8px;
    border-left: 1px solid rgba(33,59,138,.08);
    white-space: nowrap;
}

.cp-price-card.cp-price-featured .cp-plan-box-mid {
    border-left-color: rgba(255,255,255,.12);
}

.cp-plan-price {
    font-size: .95rem;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.2;
}

.cp-price-card.cp-price-featured .cp-plan-price { color: #fff; }

.cp-plan-fee {
    font-size: .68rem;
    color: var(--text-mid);
    white-space: nowrap;
}

.cp-price-card.cp-price-featured .cp-plan-fee { color: rgba(255,255,255,.55); }

/* Right: "Aggiungi" CTA chip */
.cp-plan-box-right {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 8px 14px;
    margin: 8px 10px 8px 8px;
    background: var(--cyan);
    color: #fff;
    border-radius: var(--radius-pill);
    font-size: .76rem;
    font-weight: 700;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background var(--transition);
    line-height: 1;
}

.cp-plan-box:hover .cp-plan-box-right,
.cp-plan-box:focus-visible .cp-plan-box-right {
    background: var(--navy);
}

.cp-plan-box.cp-added .cp-plan-box-right {
    background: var(--success);
}

.cp-plan-box-right svg {
    flex-shrink: 0;
    transition: transform var(--transition);
}

.cp-plan-box:hover .cp-plan-box-right svg {
    transform: scale(1.1);
}

/* keep old .cp-plan-cta in case other templates still use it */
.cp-plan-cta {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 12px;
    background: var(--cyan);
    color: #fff;
    border-radius: var(--radius-pill);
    font-size: .78rem;
    font-weight: 700;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background var(--transition);
}

.cp-plan-box:hover .cp-plan-cta { background: var(--navy); }
.cp-plan-box.cp-added .cp-plan-cta { background: var(--success); }

.cp-price-iva {
    font-size: .72rem;
    color: var(--text-mid);
    margin: 8px 0 0;
    text-align: center;
}

.cp-price-card.cp-price-featured .cp-price-iva { color: rgba(255,255,255,.5); }

/* ============================================================
   PAGINA COMMISSIONI PER SERVIZIO
   ============================================================ */

.cp-commissioni {}

.cp-comm-category {
    margin-bottom: 40px;
}

.cp-comm-cat-title {
    margin-bottom: 16px;
}

.cp-comm-table-wrap {
    overflow-x: auto;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

.cp-comm-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--white);
    font-size: .9rem;
}

.cp-comm-table th {
    background: rgba(33,59,138,.04);
    color: var(--text-mid);
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid rgba(33,59,138,.08);
}

.cp-comm-table td {
    padding: 14px 16px;
    border-bottom: 1px solid rgba(33,59,138,.06);
    vertical-align: middle;
}

td.cp-comm-piano {
    font-size: 1rem;
    font-weight: 600;
    text-transform: capitalize;
}

.cp-comm-table tr:last-child td { border-bottom: none; }

.cp-comm-product-name strong { color: var(--navy); }

.cp-col-price { white-space: nowrap; }
.cp-col-comm  { white-space: nowrap; text-align: center; }

.cp-comm-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: var(--radius-pill);
    font-size: .8rem;
    font-weight: 700;
}

.cp-comm-monthly {
    background: rgba(0,159,227,.1);
    color: #0077aa;
}

.cp-comm-initial {
    background: rgba(33,59,138,.1);
    color: var(--navy);
}

.cp-comm-empty { color: rgba(33,59,138,.25); }

.cp-comm-legend {
    margin-top: 8px;
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    padding: 16px 20px;
    background: var(--white);
    border-radius: var(--radius-md);
    border: 1px solid rgba(33,59,138,.08);
}

.cp-comm-legend-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: .82rem;
    color: var(--text-mid);
}

/* ── Commissioni: layout mobile a card raggruppata (no scroll orizzontale) ── */
@media (max-width: 768px) {

    .cp-comm-table-wrap {
        overflow-x: visible;
        background: transparent;
        box-shadow: none;
        border-radius: 0;
    }

    .cp-comm-table,
    .cp-comm-table tbody {
        display: block;
        width: 100%;
    }

    .cp-comm-table thead { display: none; }

    /* ── Reset base di ogni riga ── */
    .cp-comm-table tr {
        display: block;
        background: var(--white);
        border-left:  1px solid rgba(33,59,138,.10);
        border-right: 1px solid rgba(33,59,138,.10);
        border-top:   none;
        border-bottom: none;
        border-radius: 0;
        margin: 0;
        box-shadow: none;
    }

    /* Prima riga del gruppo (o prodotto singolo) */
    .cp-comm-table tr.cp-var-first {
        border-top: 1px solid rgba(33,59,138,.10);
        border-radius: var(--radius-md) var(--radius-md) 0 0;
        overflow: hidden;
    }

    tr.cp-var-mid:not(.cp-var-first), .cp-var-last:not(.cp-var-first) {
        border-top: 2px dashed rgb(12 32 92 / 21%) !important;
    }

    table.cp-table.cp-comm-table {
        background: none;
    }

    /* Ultima riga del gruppo */
    .cp-comm-table tr.cp-var-last {
        border-bottom: 1px solid rgba(33,59,138,.10);
        border-radius: 0 0 var(--radius-md) var(--radius-md);
        margin-bottom: 20px;
        box-shadow: var(--shadow-sm);
    }

    /* Riga che è sia prima che ultima (prodotto semplice o variante unica) */
    .cp-comm-table tr.cp-var-first.cp-var-last {
        border-radius: var(--radius-md);
        border-bottom: 1px solid rgba(33,59,138,.10);
        box-shadow: var(--shadow-sm);
    }

    /* ── Cella nome prodotto: header della card ── */
    td.cp-comm-product-name {
        display: block;
        width: 100% !important;
        background: rgba(33,59,138,.04);
        padding: 12px 16px;
        border-bottom: 1px solid rgba(33,59,138,.1);
        font-size: .95rem;
    }

    /* ── Righe dati: label a sinistra, valore a destra ── */
    .cp-comm-table td:not(.cp-comm-product-name) {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 10px 16px;
        border-bottom: 1px solid rgba(33,59,138,.04);
        font-size: .88rem;
        text-align: right;
        white-space: normal;
    }

    .cp-comm-table td:not(.cp-comm-product-name):last-child {
        border-bottom: none;
    }

    .cp-comm-table td[data-label]::before {
        content: attr(data-label);
        font-size: .72rem;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: .05em;
        color: var(--text-mid);
        flex-shrink: 0;
        text-align: left;
        margin-right: 12px;
    }

    td.cp-comm-piano { font-size: .9rem; }
    .cp-col-comm     { text-align: right; }
}
