/* ==========================================================================
   WEBSITISM — Affiliate Toolkit Styles
   Product boxes, comparison tables, pros/cons, verdict, CTAs
   ========================================================================== */


/* ==========================================================================
   DISCLOSURE NOTICE
   ========================================================================== */

.wsaf-disclosure {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 14px 18px;
    margin-bottom: var(--ws-space-8);
    background: rgba(0, 201, 219, 0.04);
    border: 1px solid rgba(0, 201, 219, 0.12);
    border-radius: var(--ws-radius-lg);
    font-size: var(--ws-text-xs);
    color: var(--ws-text-faint);
    line-height: 1.6;
}

.wsaf-disclosure svg {
    flex-shrink: 0;
    margin-top: 2px;
    color: var(--ws-accent);
    opacity: 0.6;
}


/* ==========================================================================
   STAR RATINGS
   ========================================================================== */

.wsaf-stars {
    display: inline-flex;
    align-items: center;
    gap: 2px;
}

.wsaf-star {
    color: #f59e0b;
}

.wsaf-star--empty {
    color: var(--ws-text-faint);
    opacity: 0.4;
}

.wsaf-stars__num {
    margin-left: 6px;
    font-family: var(--ws-font-mono);
    font-size: var(--ws-text-xs);
    font-weight: 600;
    color: var(--ws-text-heading);
}


/* ==========================================================================
   PRODUCT REVIEW BOX
   ========================================================================== */

.wsaf-product-box {
    position: relative;
    padding: 28px;
    margin: var(--ws-space-8) 0;
    background: var(--ws-surface-1);
    border: 1px solid var(--ws-border);
    border-radius: var(--ws-radius-xl);
    overflow: hidden;
}

.wsaf-product-box__badge {
    position: absolute;
    top: 0;
    right: 24px;
    background: linear-gradient(135deg, #f59e0b, #ef4444);
    color: #fff;
    font-family: var(--ws-font-mono);
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 6px 16px 8px;
    border-radius: 0 0 var(--ws-radius-md) var(--ws-radius-md);
}

.wsaf-product-box__header {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 16px;
}

.wsaf-product-box__img {
    width: 80px;
    height: 80px;
    flex-shrink: 0;
    border-radius: var(--ws-radius-lg);
    overflow: hidden;
    background: var(--ws-surface-2);
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--ws-border);
}

.wsaf-product-box__img img {
    max-width: 60px;
    max-height: 60px;
    object-fit: contain;
}

.wsaf-product-box__name {
    font-size: var(--ws-text-xl);
    margin: 0 0 4px;
}

.wsaf-product-box__rating {
    margin-bottom: 2px;
}

.wsaf-product-box__price {
    font-size: var(--ws-text-xs);
    color: var(--ws-text-muted);
}

.wsaf-product-box__price strong {
    color: var(--ws-accent);
    font-size: var(--ws-text-sm);
}

.wsaf-product-box__summary {
    color: var(--ws-text-muted);
    font-size: var(--ws-text-sm);
    line-height: 1.7;
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--ws-border);
}

.wsaf-product-box__lists {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 24px;
}

.wsaf-product-box__list-title {
    display: block;
    font-size: var(--ws-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 10px;
    color: var(--ws-text-heading);
}

.wsaf-product-box__pros ul,
.wsaf-product-box__cons ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.wsaf-product-box__pros li,
.wsaf-product-box__cons li {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: var(--ws-text-sm);
    color: var(--ws-text-muted);
    margin-bottom: 8px;
    line-height: 1.5;
}

.wsaf-product-box__pros li svg {
    flex-shrink: 0;
    color: #4ade80;
    margin-top: 3px;
}

.wsaf-product-box__cons li svg {
    flex-shrink: 0;
    color: #f87171;
    margin-top: 3px;
}

.wsaf-product-box__footer {
    display: flex;
    align-items: center;
    gap: 16px;
}

.wsaf-product-box__btn {
    flex: 1;
    justify-content: center;
    padding: 14px 24px;
    font-size: var(--ws-text-sm);
}


/* ==========================================================================
   COMPARISON TABLE
   ========================================================================== */

.wsaf-comparison {
    margin: var(--ws-space-8) 0;
}

.wsaf-comparison__title {
    font-size: var(--ws-text-xl);
    margin-bottom: var(--ws-space-4);
}

.wsaf-comparison__scroll {
    overflow-x: auto;
    border-radius: var(--ws-radius-xl);
    border: 1px solid var(--ws-border);
}

.wsaf-comparison__table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--ws-text-sm);
}

.wsaf-comparison__table thead {
    background: var(--ws-surface-1);
}

.wsaf-comparison__table th {
    padding: 14px 18px;
    text-align: left;
    font-family: var(--ws-font-mono);
    font-size: var(--ws-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--ws-text-faint);
    border-bottom: 1px solid var(--ws-border);
    white-space: nowrap;
}

.wsaf-comparison__table td {
    padding: 16px 18px;
    border-bottom: 1px solid var(--ws-border);
    color: var(--ws-text-secondary);
    vertical-align: middle;
}

.wsaf-comparison__table tr:last-child td {
    border-bottom: none;
}

.wsaf-comparison__table tbody tr {
    transition: background 0.2s;
}

.wsaf-comparison__table tbody tr:hover {
    background: rgba(0, 201, 219, 0.03);
}

.wsaf-comparison__row--top {
    background: rgba(0, 201, 219, 0.04) !important;
}

.wsaf-comparison__row--top td:first-child {
    border-left: 3px solid var(--ws-accent);
}

.wsaf-comparison__rank {
    font-family: var(--ws-font-mono);
    font-weight: 600;
    color: var(--ws-text-heading);
    white-space: nowrap;
}

.wsaf-comparison__crown {
    margin-right: 4px;
}

.wsaf-comparison__btn {
    padding: 8px 18px;
    font-size: var(--ws-text-xs);
    white-space: nowrap;
}


/* ==========================================================================
   PROS / CONS BLOCK
   ========================================================================== */

.wsaf-proscons {
    margin: var(--ws-space-8) 0;
    border: 1px solid var(--ws-border);
    border-radius: var(--ws-radius-xl);
    overflow: hidden;
}

.wsaf-proscons__title {
    font-size: var(--ws-text-md);
    padding: 16px 24px;
    margin: 0;
    border-bottom: 1px solid var(--ws-border);
    background: var(--ws-surface-1);
}

.wsaf-proscons__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.wsaf-proscons__col {
    padding: 20px 24px;
}

.wsaf-proscons__col--pros {
    border-right: 1px solid var(--ws-border);
}

.wsaf-proscons__heading {
    display: block;
    font-size: var(--ws-text-sm);
    font-weight: 600;
    margin-bottom: 12px;
    color: var(--ws-text-heading);
}

.wsaf-proscons__col ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.wsaf-proscons__col li {
    font-size: var(--ws-text-sm);
    color: var(--ws-text-muted);
    padding: 6px 0;
    line-height: 1.5;
}

.wsaf-proscons__col--pros li::before {
    content: "✓ ";
    color: #4ade80;
    font-weight: 700;
}

.wsaf-proscons__col--cons li::before {
    content: "✗ ";
    color: #f87171;
    font-weight: 700;
}


/* ==========================================================================
   VERDICT BOX
   ========================================================================== */

.wsaf-verdict {
    position: relative;
    margin: var(--ws-space-10) 0;
    padding: 32px;
    background: linear-gradient(135deg, rgba(0, 201, 219, 0.06), rgba(0, 201, 219, 0.02));
    border: 1px solid rgba(0, 201, 219, 0.2);
    border-radius: var(--ws-radius-xl);
    text-align: center;
}

.wsaf-verdict__label {
    display: inline-block;
    font-family: var(--ws-font-mono);
    font-size: 0.65rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--ws-accent);
    background: var(--ws-accent-muted);
    padding: 4px 14px;
    border-radius: var(--ws-radius-full);
    margin-bottom: 12px;
}

.wsaf-verdict__product {
    font-size: var(--ws-text-2xl);
    margin: 0 0 8px;
}

.wsaf-verdict__rating {
    margin-bottom: 16px;
    display: flex;
    justify-content: center;
}

.wsaf-verdict__text {
    color: var(--ws-text-muted);
    font-size: var(--ws-text-md);
    line-height: 1.7;
    max-width: 640px;
    margin: 0 auto 24px;
}

.wsaf-verdict__btn {
    padding: 14px 32px;
    font-size: var(--ws-text-sm);
}


/* ==========================================================================
   AFFILIATE CTA BLOCK
   ========================================================================== */

.wsaf-cta-block {
    margin: var(--ws-space-8) 0;
    padding: 28px 32px;
    background: var(--ws-surface-1);
    border: 1px dashed rgba(0, 201, 219, 0.25);
    border-radius: var(--ws-radius-xl);
    text-align: center;
}

.wsaf-cta-block__text {
    font-size: var(--ws-text-md);
    font-weight: 500;
    color: var(--ws-text-heading);
    margin: 0 0 16px;
}

.wsaf-cta-block__btn {
    padding: 12px 28px;
    margin-bottom: 8px;
}

.wsaf-cta-block__sub {
    display: block;
    font-size: var(--ws-text-xs);
    color: var(--ws-text-faint);
    margin-top: 8px;
}


/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 768px) {
    .wsaf-product-box__header {
        flex-direction: column;
        align-items: flex-start;
    }

    .wsaf-product-box__lists {
        grid-template-columns: 1fr;
    }

    .wsaf-proscons__grid {
        grid-template-columns: 1fr;
    }

    .wsaf-proscons__col--pros {
        border-right: none;
        border-bottom: 1px solid var(--ws-border);
    }

    .wsaf-comparison__table {
        font-size: var(--ws-text-xs);
    }

    .wsaf-comparison__table th,
    .wsaf-comparison__table td {
        padding: 10px 12px;
    }

    .wsaf-product-box {
        padding: 20px;
    }

    .wsaf-verdict {
        padding: 24px;
    }
}
