/**
 * Kolirys — Page Tarifs
 */

.page-pricing {
    background: var(--k-surface-page);
    color: var(--k-text-primary);
    font-family: var(--k-font-family);
    overflow-x: clip;
    width: 100%;
}

.page-pricing .kl-hero {
    padding-top: calc(var(--kl-nav-h) + 52px);
    padding-bottom: var(--k-spacing-xl);
}

.page-pricing .kl-hero__accent { color: var(--k-accent-highlight); }

.page-pricing .kl-hero__grid--single {
    grid-template-columns: 1fr;
    max-width: var(--k-hero-centered-max, 920px);
    width: 100%;
    margin-inline: auto;
}

.page-pricing .kl-hero__content {
    text-align: center;
    width: 100%;
}

.page-pricing .kl-hero__content .kl-lead {
    margin-left: auto;
    margin-right: auto;
}

.page-pricing .kl-feat-crumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    justify-content: center;
}

.page-pricing .kl-hero .kl-reveal--ready {
    opacity: 1;
    transform: none;
}

.page-pricing .kl-section .kl-reveal--ready,
.page-pricing .kl-section .kl-reveal--visible {
    opacity: 1;
    transform: none;
}

/* ── Onglets profil ── */
.kl-price-tabs {
    display: inline-flex;
    gap: 6px;
    padding: 6px;
    background: var(--k-surface-muted);
    border: 1px solid var(--k-border-subtle);
    border-radius: var(--k-radius-full);
    margin-top: var(--k-spacing-lg);
    margin-inline: auto;
}

.kl-price-tabs__item {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 20px;
    border-radius: var(--k-radius-full);
    font-size: var(--k-font-size-sm);
    font-weight: var(--k-font-weight-semibold);
    color: var(--k-text-secondary);
    text-decoration: none;
    transition: all var(--k-transition-base);
    white-space: nowrap;
}

.kl-price-tabs__item:hover {
    color: var(--k-text-primary);
    text-decoration: none;
}

.kl-price-tabs__item--active {
    background: var(--k-surface-card);
    color: var(--k-brand-secondary);
    box-shadow: var(--k-shadow-sm);
}

/* ── Cartes tarifs ── */
.kl-price-cards {
    display: grid;
    gap: var(--k-spacing-lg);
    margin-bottom: var(--k-spacing-2xl);
}

.kl-price-cards--4 { grid-template-columns: repeat(4, 1fr); }
.kl-price-cards--1 { grid-template-columns: minmax(260px, 360px); justify-content: center; }

.kl-price-card {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: var(--k-spacing-xl);
    background: var(--k-surface-card);
    border: 1px solid var(--k-border-subtle);
    border-radius: var(--k-radius-xl);
    transition: box-shadow var(--k-transition-base), border-color var(--k-transition-base), transform var(--k-transition-base);
}

.kl-price-card:hover {
    border-color: var(--k-border-strong);
    box-shadow: var(--k-shadow-md);
}

.kl-price-card--featured {
    border-color: var(--k-brand-secondary);
    box-shadow: var(--k-shadow-glow);
    transform: scale(1.02);
    z-index: 1;
}

.kl-price-card--free {
    background: linear-gradient(180deg, var(--k-surface-card) 0%, var(--k-surface-muted) 100%);
}

.kl-price-card__badge {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    padding: 4px 14px;
    background: var(--k-brand-gradient);
    color: #fff;
    font-size: 0.6875rem;
    font-weight: var(--k-font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-radius: var(--k-radius-full);
    white-space: nowrap;
}

.kl-price-card__name {
    font-size: var(--k-font-size-lg);
    font-weight: var(--k-font-weight-bold);
    margin: 0 0 4px;
    color: var(--k-text-primary);
}

.kl-price-card__for {
    font-size: 0.8125rem;
    color: var(--k-text-muted);
    margin: 0 0 var(--k-spacing-md);
    line-height: var(--k-line-height-normal);
}

.kl-price-card__amount {
    font-size: 2.25rem;
    font-weight: var(--k-font-weight-bold);
    color: var(--k-text-primary);
    line-height: 1.1;
    margin-bottom: 4px;
}

.kl-price-card__amount--free {
    color: var(--k-brand-secondary);
}

.kl-price-card__amount span {
    font-size: var(--k-font-size-sm);
    font-weight: var(--k-font-weight-medium);
    color: var(--k-text-muted);
}

.kl-price-card__annual {
    font-size: 0.8125rem;
    color: var(--k-text-secondary);
    margin: 0 0 var(--k-spacing-lg);
    min-height: 1.25rem;
}

.kl-price-card__highlights {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--k-spacing-lg);
    flex: 1;
}

.kl-price-card__highlights li {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: var(--k-font-size-sm);
    color: var(--k-text-secondary);
    margin-bottom: 8px;
    line-height: var(--k-line-height-normal);
}

.kl-price-card__highlights .fa-check {
    color: var(--k-success);
    margin-top: 3px;
    flex-shrink: 0;
}

.kl-price-card__cta {
    width: 100%;
    margin-top: auto;
}

/* ── Bandeau promo ── */
.kl-price-promo {
    text-align: center;
    padding: var(--k-spacing-md) var(--k-spacing-lg);
    background: var(--k-success-soft);
    border: 1px solid rgba(34, 197, 94, 0.2);
    border-radius: var(--k-radius-lg);
    margin-bottom: var(--k-spacing-xl);
    font-size: var(--k-font-size-sm);
    color: var(--k-text-secondary);
}

.kl-price-promo strong { color: var(--k-success); }

/* ── Tableau comparatif ── */
.kl-price-compare-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border: 1px solid var(--k-border-subtle);
    border-radius: var(--k-radius-xl);
    background: var(--k-surface-card);
    box-shadow: var(--k-shadow-sm);
}

.kl-price-compare {
    width: 100%;
    min-width: 640px;
    border-collapse: collapse;
    font-size: var(--k-font-size-sm);
}

.kl-price-compare thead th {
    padding: var(--k-spacing-lg) var(--k-spacing-md);
    text-align: center;
    vertical-align: bottom;
    border-bottom: 1px solid var(--k-border-subtle);
    background: var(--k-surface-muted);
}

.kl-price-compare thead th:first-child {
    text-align: left;
    position: sticky;
    left: 0;
    z-index: 2;
    background: var(--k-surface-muted);
    min-width: 220px;
}

.kl-price-compare__plan-name {
    font-size: var(--k-font-size-base);
    font-weight: var(--k-font-weight-bold);
    color: var(--k-text-primary);
    margin-bottom: 4px;
}

.kl-price-compare__plan-price {
    font-size: 1.25rem;
    font-weight: var(--k-font-weight-bold);
    color: var(--k-brand-secondary);
}

.kl-price-compare__plan-price small {
    font-size: 0.75rem;
    font-weight: var(--k-font-weight-normal);
    color: var(--k-text-muted);
}

.kl-price-compare tbody tr {
    border-bottom: 1px solid var(--k-border-subtle);
}

.kl-price-compare tbody tr:last-child { border-bottom: none; }

.kl-price-compare tbody td {
    padding: 12px var(--k-spacing-md);
    text-align: center;
    vertical-align: middle;
}

.kl-price-compare tbody td:first-child {
    text-align: left;
    font-weight: var(--k-font-weight-medium);
    color: var(--k-text-primary);
    position: sticky;
    left: 0;
    background: var(--k-surface-card);
    z-index: 1;
}

.kl-price-compare tbody tr:nth-child(even) td:first-child {
    background: var(--k-surface-page);
}

.kl-price-compare tbody tr:nth-child(even) {
    background: var(--k-surface-page);
}

.kl-price-compare a {
    color: var(--k-brand-secondary);
    text-decoration: none;
}

.kl-price-compare a:hover { text-decoration: underline; }

.kl-price-compare .fa-check { color: var(--k-success); }
.kl-price-compare .fa-times { color: var(--k-danger); opacity: 0.7; }
.kl-price-compare .fa-infinity { color: var(--k-brand-secondary); font-size: 0.9rem; }

.kl-price-compare__note {
    font-size: 0.75rem;
    color: var(--k-text-muted);
    display: block;
    margin-top: 2px;
}

/* ── Pied de page tarifs ── */
.kl-price-footnotes {
    text-align: center;
    margin-top: var(--k-spacing-xl);
    font-size: var(--k-font-size-sm);
    color: var(--k-text-secondary);
    line-height: var(--k-line-height-relaxed);
}

.kl-price-footnotes p { margin: 0 0 6px; }

/* ── FAQ rapide ── */
.kl-price-faq {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--k-spacing-lg);
}

.kl-price-faq__item {
    padding: var(--k-spacing-lg);
    background: var(--k-surface-card);
    border: 1px solid var(--k-border-subtle);
    border-radius: var(--k-radius-lg);
}

.kl-price-faq__item h3 {
    font-size: var(--k-font-size-base);
    font-weight: var(--k-font-weight-bold);
    margin: 0 0 8px;
}

.kl-price-faq__item p {
    font-size: var(--k-font-size-sm);
    color: var(--k-text-secondary);
    margin: 0;
    line-height: var(--k-line-height-relaxed);
}

/* ── Responsive ── */
@media (max-width: 1100px) {
    .kl-price-cards--4 { grid-template-columns: repeat(2, 1fr); }
    .kl-price-card--featured { transform: none; }
}

@media (max-width: 768px) {
    .page-pricing .kl-hero { padding-top: calc(var(--kl-nav-h) + 28px); }

    .kl-price-tabs {
        flex-direction: column;
        width: 100%;
        max-width: 420px;
        margin-inline: auto;
        border-radius: var(--k-radius-lg);
    }

    .kl-price-tabs__item { border-radius: var(--k-radius-md); }

    .kl-price-cards--4,
    .kl-price-cards--1 { grid-template-columns: 1fr; }

    .kl-price-faq { grid-template-columns: 1fr; }
}
