/* ── Geographic Arbitrage Calculator ──────────────────────────────────────── */

.ga-sep {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: var(--space-6) 0;
}

.ga-section-title {
    font-size: var(--text-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-2);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: var(--space-4);
}

/* ── Ranking grid ────────────────────────────────────────────────────────── */

.ga-ranking-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--space-3);
    margin-bottom: var(--space-6);
}

@media (max-width: 480px) {
    .ga-ranking-grid { grid-template-columns: 1fr; }
}

/* ── Rank card ───────────────────────────────────────────────────────────── */

.ga-rank-card {
    position: relative;
    background: var(--color-surface-2);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-5) var(--space-4) var(--space-4);
    transition: border-color var(--transition-fast);
}

.ga-rank-card--winner {
    border-color: var(--color-accent);
    background: linear-gradient(160deg, var(--color-surface-2) 60%, rgba(240, 160, 48, 0.06));
}

.ga-rank-card--current:not(.ga-rank-card--winner) {
    border-color: var(--color-info);
}

/* ── Badges ──────────────────────────────────────────────────────────────── */

.ga-rank-badge {
    display: inline-block;
    font-size: var(--text-xs);
    font-weight: var(--font-weight-bold);
    padding: 1px var(--space-2);
    border-radius: var(--radius-full);
    background: var(--color-surface-3);
    color: var(--color-text-3);
    letter-spacing: 0.04em;
    margin-bottom: var(--space-2);
}

.ga-rank-badge--winner {
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-accent);
    color: var(--color-bg);
    padding: 2px var(--space-3);
    white-space: nowrap;
    margin-bottom: 0;
}

.ga-rank-badge--current {
    background: rgba(88, 166, 255, 0.15);
    color: var(--color-info);
}

/* ── Card content ────────────────────────────────────────────────────────── */

.ga-country-name {
    font-size: var(--text-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-1);
    margin-bottom: var(--space-1);
}

.ga-disposable {
    font-size: var(--text-2xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-1);
    letter-spacing: -0.02em;
    font-variant-numeric: tabular-nums;
    line-height: var(--line-height-tight);
}

.ga-rank-card--winner .ga-disposable {
    color: var(--color-accent);
}

.ga-disposable-label {
    display: block;
    font-size: var(--text-xs);
    color: var(--color-text-3);
    margin-bottom: var(--space-3);
}

/* ── Breakdown inside card ───────────────────────────────────────────────── */

.ga-breakdown {
    border-top: 1px solid var(--color-border);
    padding-top: var(--space-2);
}

.ga-breakdown__row {
    display: flex;
    justify-content: space-between;
    font-size: var(--text-xs);
    color: var(--color-text-3);
    padding: var(--space-1) 0;
}

/* ── Full table ──────────────────────────────────────────────────────────── */

.ga-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.ga-full-table {
    width: 100%;
    min-width: 0;
}

.ga-col-rank {
    width: 2rem;
    white-space: nowrap;
}

.ga-row--current {
    background: rgba(88, 166, 255, 0.08);
}

.ga-row--current td {
    font-weight: var(--font-weight-semibold);
}

.ga-row--negative {
    background: rgba(220, 60, 60, 0.07);
}

.ga-row--better {
    background: rgba(60, 180, 100, 0.08);
}

.ga-row--worse {
    background: rgba(220, 60, 60, 0.07);
}

.ga-row--total td {
    font-weight: var(--font-weight-semibold);
    border-top: 1px solid var(--color-border);
}

.ga-diff-pct {
    font-weight: var(--font-weight-normal);
    font-size: var(--text-xs);
    opacity: 0.75;
    white-space: nowrap;
}

/* ── Category cost form section ──────────────────────────────────────────── */

.ga-cat-details {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    margin-bottom: var(--space-4);
}

.ga-cat-summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    font-size: var(--text-sm);
    color: var(--color-text-2);
    list-style: none;
    user-select: none;
}

.ga-cat-summary::-webkit-details-marker { display: none; }

.ga-cat-grid {
    margin-top: var(--space-3);
}

.ga-cat-hint {
    margin-top: var(--space-2);
    font-size: var(--text-xs);
}

/* ── Per-category card breakdown ─────────────────────────────────────────── */

.ga-cat-breakdown {
    border-top: 1px solid var(--color-border);
    padding-top: var(--space-2);
    margin-top: var(--space-1);
}

.ga-cat-breakdown__title {
    font-size: var(--text-xs);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-3);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: var(--space-1);
}

.ga-cat-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: var(--text-xs);
    padding: 2px 0;
    color: var(--color-text-3);
}

.ga-cat-diff {
    font-variant-numeric: tabular-nums;
    font-weight: var(--font-weight-semibold);
}

.ga-cat-diff--cheaper { color: var(--color-success); }
.ga-cat-diff--pricier { color: var(--color-error); }

/* ── Utilities ───────────────────────────────────────────────────────────── */

.text-error {
    color: var(--color-error);
}

.form-input[aria-invalid="true"] {
    border-color: var(--color-error);
    box-shadow: 0 0 0 1px var(--color-error);
}
