/* ═══════════════════════════════════════════════════════════
   Sponsorship Rate Calculator — Page-Specific Layout
   Shared components (buttons, forms, badges, cards, tabs)
   come from global CSS. This file handles ONLY layout
   unique to this tool.
   ═══════════════════════════════════════════════════════════ */

/* ── Social Proof ─────────────────────────────────────── */
.src-social-proof {
    text-align: center;
    color: var(--color-gray-500, #64748b);
    font-size: var(--font-size-sm, 14px);
    margin-top: var(--space-3, 12px);
}
.src-social-proof i {
    color: var(--color-primary, #4F46E5);
    margin-right: var(--space-1, 4px);
}

/* ── Inputs Section ───────────────────────────────────── */
.src-inputs {
    margin-bottom: var(--space-8, 32px);
}
.src-inputs__title {
    font-family: var(--font-display);
    font-size: var(--font-size-lg, 18px);
    font-weight: 700;
    color: var(--color-gray-900, #0f172a);
    margin: 0 0 var(--space-1, 4px);
}
.src-inputs__hint {
    color: var(--color-gray-500, #64748b);
    font-size: var(--font-size-sm, 14px);
    margin: 0 0 var(--space-5, 20px);
}
.src-inputs__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4, 16px);
    margin-bottom: var(--space-4, 16px);
}
.src-inputs__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4, 16px);
    margin-bottom: var(--space-4, 16px);
}
.src-number-input {
    font-size: var(--font-size-base, 16px);
    font-weight: 600;
}

/* ── Engagement Display ───────────────────────────────── */
.src-engagement-display {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--color-gray-50, #f8fafc);
    border: 1px solid var(--color-gray-200, #e2e8f0);
    border-radius: var(--radius-lg, 12px);
    padding: var(--space-3, 12px) var(--space-5, 20px);
}
.src-engagement-display__label {
    font-size: var(--font-size-sm, 14px);
    color: var(--color-gray-500, #64748b);
    display: block;
}
.src-engagement-display__value {
    font-family: var(--font-display);
    font-size: var(--font-size-xl, 20px);
    font-weight: 700;
    color: var(--color-primary, #4F46E5);
}

/* ── Results Section ──────────────────────────────────── */
.src-results {
    margin-bottom: var(--space-8, 32px);
}
.src-results__title {
    font-family: var(--font-display);
    font-size: var(--font-size-lg, 18px);
    font-weight: 700;
    color: var(--color-gray-900, #0f172a);
    margin: 0 0 var(--space-1, 4px);
}
.src-results__subtitle {
    color: var(--color-gray-500, #64748b);
    font-size: var(--font-size-sm, 14px);
    margin: 0 0 var(--space-5, 20px);
}

/* ── Rate Cards Grid ──────────────────────────────────── */
.src-rates-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4, 16px);
    margin-bottom: var(--space-6, 24px);
}
.src-rate-card {
    position: relative;
    background: var(--color-white, #fff);
    border: 1px solid var(--color-gray-200, #e2e8f0);
    border-radius: var(--radius-lg, 12px);
    padding: var(--space-5, 20px);
    transition: all 150ms ease;
}
.src-rate-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    border-color: var(--color-primary, #4F46E5);
}
.src-rate-card--featured {
    border-color: var(--color-primary, #4F46E5);
    box-shadow: 0 0 0 1px var(--color-primary, #4F46E5);
}
.src-rate-card__badge {
    position: absolute;
    top: -10px;
    right: 16px;
    background: var(--color-primary, #4F46E5);
    color: var(--color-white, #fff);
    font-size: var(--font-size-xs, 12px);
    font-weight: 700;
    padding: 2px 10px;
    border-radius: 20px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.src-rate-card__header {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3, 12px);
    margin-bottom: var(--space-4, 16px);
}
.src-rate-card__icon {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-gray-50, #f8fafc);
    border-radius: var(--radius-md, 8px);
    color: var(--color-primary, #4F46E5);
    font-size: var(--font-size-base, 16px);
    flex-shrink: 0;
}
.src-rate-card__title {
    font-family: var(--font-display);
    font-size: var(--font-size-sm, 14px);
    font-weight: 700;
    color: var(--color-gray-900, #0f172a);
    margin: 0;
    line-height: 1.3;
}
.src-rate-card__desc {
    font-size: var(--font-size-xs, 12px);
    color: var(--color-gray-500, #64748b);
    line-height: 1.3;
}
.src-rate-card__range {
    text-align: center;
    margin-bottom: var(--space-1, 4px);
}
.src-rate-card__dollar {
    font-family: var(--font-display);
    font-size: var(--font-size-lg, 18px);
    font-weight: 700;
    color: var(--color-gray-400, #94a3b8);
}
.src-rate-card__low,
.src-rate-card__high {
    font-family: var(--font-display);
    font-size: 32px;
    font-weight: 800;
    color: var(--color-gray-900, #0f172a);
}
.src-rate-card__pct {
    font-family: var(--font-display);
    font-size: var(--font-size-lg, 18px);
    font-weight: 700;
    color: var(--color-gray-400, #94a3b8);
}
.src-rate-card__sep {
    font-size: var(--font-size-lg, 18px);
    color: var(--color-gray-300, #cbd5e1);
    margin: 0 var(--space-1, 4px);
}
.src-rate-card__per {
    display: block;
    text-align: center;
    font-size: var(--font-size-xs, 12px);
    color: var(--color-gray-500, #64748b);
}

/* ── Benchmark Comparison ─────────────────────────────── */
.src-benchmark {
    background: var(--color-gray-50, #f8fafc);
    border: 1px solid var(--color-gray-200, #e2e8f0);
    border-radius: var(--radius-lg, 12px);
    padding: var(--space-5, 20px);
    margin-bottom: var(--space-5, 20px);
}
.src-benchmark__header {
    display: flex;
    align-items: center;
    gap: var(--space-2, 8px);
    font-size: var(--font-size-sm, 14px);
    color: var(--color-gray-700, #334155);
    margin-bottom: var(--space-4, 16px);
}
.src-benchmark__header i {
    color: var(--color-primary, #4F46E5);
}
.src-benchmark__bar-wrap {
    position: relative;
}
.src-benchmark__bar {
    height: 8px;
    background: var(--color-gray-200, #e2e8f0);
    border-radius: 4px;
    position: relative;
    margin-bottom: var(--space-6, 24px);
}
.src-benchmark__bar-avg,
.src-benchmark__bar-you {
    position: absolute;
    top: -6px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    transform: translateX(-50%);
    transition: left 400ms ease;
}
.src-benchmark__bar-avg {
    background: var(--color-gray-400, #94a3b8);
}
.src-benchmark__bar-you {
    background: var(--color-primary, #4F46E5);
}
.src-benchmark__bar-label {
    position: absolute;
    top: 24px;
    left: 50%;
    transform: translateX(-50%);
    font-size: var(--font-size-xs, 12px);
    font-weight: 600;
    white-space: nowrap;
}
.src-benchmark__bar-avg .src-benchmark__bar-label {
    color: var(--color-gray-500, #64748b);
}
.src-benchmark__bar-you .src-benchmark__bar-label {
    color: var(--color-primary, #4F46E5);
}
.src-benchmark__legend {
    display: flex;
    gap: var(--space-5, 20px);
    font-size: var(--font-size-xs, 12px);
    color: var(--color-gray-500, #64748b);
}
.src-legend-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-right: var(--space-1, 4px);
    vertical-align: middle;
}
.src-legend-dot--avg { background: var(--color-gray-400, #94a3b8); }
.src-legend-dot--you { background: var(--color-primary, #4F46E5); }

/* ── Share Bar ────────────────────────────────────────── */
.src-share-bar {
    display: flex;
    gap: var(--space-3, 12px);
    justify-content: center;
    flex-wrap: wrap;
}
.src-share-btn--success {
    color: var(--color-success, #16a34a) !important;
    border-color: var(--color-success, #16a34a) !important;
}

/* ── Negotiation Guide ────────────────────────────────── */
.src-negotiation {
    margin-bottom: var(--space-8, 32px);
    border-top: 1px solid var(--color-gray-200, #e2e8f0);
    padding-top: var(--space-8, 32px);
}
.src-negotiation__title {
    font-family: var(--font-display);
    font-size: var(--font-size-xl, 20px);
    font-weight: 700;
    color: var(--color-gray-900, #0f172a);
    margin: 0 0 var(--space-1, 4px);
}
.src-negotiation__title i {
    color: var(--color-primary, #4F46E5);
    margin-right: var(--space-2, 8px);
}
.src-negotiation__subtitle {
    color: var(--color-gray-500, #64748b);
    font-size: var(--font-size-sm, 14px);
    margin: 0 0 var(--space-6, 24px);
}

/* ── Negotiation Tiers ────────────────────────────────── */
.src-negotiation__tiers {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4, 16px);
    margin-bottom: var(--space-6, 24px);
}
.src-tier {
    border-radius: var(--radius-lg, 12px);
    padding: var(--space-5, 20px);
    text-align: center;
}
.src-tier--floor {
    background: var(--color-danger-50, #fef2f2);
    border: 1px solid var(--color-danger-200, #fecaca);
}
.src-tier--ask {
    background: var(--color-primary-50, #eef2ff);
    border: 2px solid var(--color-primary, #4F46E5);
}
.src-tier--premium {
    background: var(--color-purple-50, #faf5ff);
    border: 1px solid var(--color-purple-200, #e9d5ff);
}
.src-tier__label {
    font-size: var(--font-size-xs, 12px);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--space-1, 4px);
}
.src-tier--floor .src-tier__label { color: var(--color-danger, #dc2626); }
.src-tier--ask .src-tier__label { color: var(--color-primary, #4F46E5); }
.src-tier--premium .src-tier__label { color: var(--color-primary-dark, #7c3aed); }
.src-tier__desc {
    font-size: var(--font-size-xs, 12px);
    color: var(--color-gray-500, #64748b);
    margin-bottom: var(--space-3, 12px);
}
.src-tier__value {
    margin-bottom: var(--space-3, 12px);
}
.src-tier__dollar {
    font-family: var(--font-display);
    font-size: var(--font-size-lg, 18px);
    font-weight: 700;
    color: var(--color-gray-400, #94a3b8);
}
.src-tier__value span:last-child {
    font-family: var(--font-display);
    font-size: 32px;
    font-weight: 800;
    color: var(--color-gray-900, #0f172a);
}
.src-tier__explanation {
    font-size: var(--font-size-xs, 12px);
    color: var(--color-gray-500, #64748b);
    margin: 0;
    line-height: 1.5;
}

/* ── Add-On Multipliers ───────────────────────────────── */
.src-multipliers {
    margin-bottom: var(--space-6, 24px);
}
.src-multipliers__title {
    font-family: var(--font-display);
    font-size: var(--font-size-base, 16px);
    font-weight: 700;
    color: var(--color-gray-900, #0f172a);
    margin: 0 0 var(--space-4, 16px);
}
.src-multipliers__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-3, 12px);
}
.src-multiplier {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3, 12px);
    background: var(--color-gray-50, #f8fafc);
    border: 1px solid var(--color-gray-200, #e2e8f0);
    border-radius: var(--radius-md, 8px);
    padding: var(--space-3, 12px) var(--space-4, 16px);
    transition: all 150ms ease;
}
.src-multiplier:hover {
    border-color: var(--color-primary, #4F46E5);
    background: var(--color-white, #fff);
}
.src-multiplier__icon {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-white, #fff);
    border-radius: var(--radius-md, 8px);
    color: var(--color-primary, #4F46E5);
    flex-shrink: 0;
    font-size: var(--font-size-sm, 14px);
}
.src-multiplier strong {
    font-size: var(--font-size-sm, 14px);
    color: var(--color-gray-900, #0f172a);
}
.src-multiplier__addon {
    font-family: var(--font-display);
    font-size: var(--font-size-sm, 14px);
    font-weight: 700;
    color: var(--color-primary, #4F46E5);
    margin-left: var(--space-2, 8px);
}
.src-multiplier__hint {
    display: block;
    font-size: var(--font-size-xs, 12px);
    color: var(--color-gray-500, #64748b);
    line-height: 1.4;
}

/* ── Rate Card Actions ────────────────────────────────── */
.src-ratecard-actions {
    text-align: center;
    padding: var(--space-6, 24px) 0;
}
.src-ratecard-actions__hint {
    font-size: var(--font-size-xs, 12px);
    color: var(--color-gray-500, #64748b);
    margin-top: var(--space-2, 8px);
}

/* ── Benchmarks Table ─────────────────────────────────── */
.src-benchmarks-table {
    margin-top: var(--space-8, 32px);
    border-top: 1px solid var(--color-gray-200, #e2e8f0);
    padding-top: var(--space-8, 32px);
}
.src-section-title {
    font-family: var(--font-display);
    font-size: var(--font-size-lg, 18px);
    font-weight: 700;
    color: var(--color-gray-900, #0f172a);
    margin: 0 0 var(--space-5, 20px);
    text-align: center;
}
.src-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.src-ref-table {
    min-width: 480px;
}
.src-ref-table th {
    font-size: var(--font-size-xs, 12px);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — Mobile (max-width: 767px)
   ═══════════════════════════════════════════════════════════ */

@media (max-width: 767px) {
    .src-inputs__grid {
        grid-template-columns: 1fr;
        gap: var(--space-3, 12px);
    }
    .src-inputs__row {
        grid-template-columns: 1fr;
        gap: var(--space-3, 12px);
    }

    .src-engagement-display {
        flex-direction: column;
        gap: var(--space-2, 8px);
        text-align: center;
    }

    .src-rates-grid {
        grid-template-columns: 1fr;
        gap: var(--space-3, 12px);
    }

    .src-rate-card {
        padding: var(--space-4, 16px);
    }
    .src-rate-card__low,
    .src-rate-card__high {
        font-size: 26px;
    }

    .src-negotiation__tiers {
        grid-template-columns: 1fr;
        gap: var(--space-3, 12px);
    }
    .src-tier__value span:last-child {
        font-size: 28px;
    }

    .src-multipliers__grid {
        grid-template-columns: 1fr;
    }

    .src-benchmark__legend {
        flex-direction: column;
        gap: var(--space-2, 8px);
    }

    .src-share-bar {
        flex-direction: column;
    }
    .src-share-bar .button {
        width: 100%;
    }
}
