/* HornSports Recruiting Tracker Widget v1.0 */

.hs-rt-widget {
    background: #ffffff;
    border-radius: 0.75rem;
    overflow: hidden;
    border: 1px solid #e0ddd8;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    font-family: 'Oswald', 'Arial Narrow', sans-serif !important;
}

/* ---- HEADER ---- */
.hs-rt-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-left: 4px solid #bf5700;
    background: #f7f6f2;
    border-bottom: 1px solid #e0ddd8;
}
.hs-rt-header-titles {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.hs-rt-sport {
    font-family: 'Oswald', 'Arial Narrow', sans-serif !important;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #bf5700;
}
.hs-rt-title {
    font-family: 'Oswald', 'Arial Narrow', sans-serif !important;
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    color: #1a1a1a;
    margin: 0;
    line-height: 1.2;
}
.hs-rt-count {
    font-family: 'Oswald', 'Arial Narrow', sans-serif !important;
    font-size: 1.4rem;
    font-weight: 700;
    color: #1a1a1a;
    line-height: 1;
    text-align: right;
}
.hs-rt-count span {
    display: block;
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #7a7570;
}

/* ---- COLUMN LABELS ---- */
.hs-rt-col-labels {
    display: grid;
    grid-template-columns: 2fr 0.6fr 1.5fr 1fr 1.1fr;
    gap: 0;
    padding: 0.4rem 1.25rem;
    background: #edeae5;
    border-bottom: 1px solid #dcd9d5;
}
.hs-rt-col-labels span {
    font-family: 'Oswald', 'Arial Narrow', sans-serif !important;
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #7a7570;
}

/* ---- ENTRIES ---- */
.hs-rt-entries { display: flex; flex-direction: column; }

.hs-rt-entry {
    display: grid;
    grid-template-columns: 2fr 0.6fr 1.5fr 1fr 1.1fr;
    gap: 0;
    align-items: center;
    padding: 0.7rem 1.25rem;
    border-bottom: 1px solid #f0ede8;
    transition: background 150ms ease;
}
.hs-rt-entry:last-child { border-bottom: none; }
.hs-rt-entry:hover { background: #faf9f7 !important; }
.hs-rt-entry:nth-child(even) { background: #f7f6f2; }

.hs-rt-name {
    font-family: 'Oswald', 'Arial Narrow', sans-serif !important;
    font-size: 0.95rem;
    font-weight: 600;
    color: #1a1a1a;
}
.hs-rt-name a {
    color: #1a1a1a;
    font-family: 'Oswald', 'Arial Narrow', sans-serif !important;
    text-decoration: none;
    transition: color 150ms ease;
}
.hs-rt-name a:hover { color: #bf5700; }

.hs-rt-position {
    font-family: 'Oswald', 'Arial Narrow', sans-serif !important;
    font-size: 0.85rem;
    font-weight: 700;
    color: #bf5700;
    letter-spacing: 0.05em;
}
.hs-rt-hometown {
    font-family: 'Oswald', 'Arial Narrow', sans-serif !important;
    font-size: 0.82rem;
    font-weight: 400;
    color: #5a5752;
}
.hs-rt-ranking {
    font-family: 'Oswald', 'Arial Narrow', sans-serif !important;
    font-size: 0.82rem;
    font-weight: 500;
    color: #1a1a1a;
    letter-spacing: 0.02em;
}

/* ---- STATUS BADGES ---- */
.hs-rt-badge {
    display: inline-block;
    font-family: 'Oswald', 'Arial Narrow', sans-serif !important;
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 3px 8px;
    border-radius: 999px;
    white-space: nowrap;
}
.hs-rt-badge--committed   { background: #dff0d8; color: #2d6a1f; }
.hs-rt-badge--signed      { background: #d4edda; color: #155724; }
.hs-rt-badge--enrolled    { background: #cce5ff; color: #004085; }
.hs-rt-badge--target      { background: #fff3cd; color: #856404; }
.hs-rt-badge--decommitted { background: #f8d7da; color: #721c24; }

/* ---- FOOTER / CTA BUTTON ---- */
.hs-rt-footer {
    padding: 1rem 1.25rem;
    border-top: 1px solid #e0ddd8;
    background: #f7f6f2;
    display: flex;
    justify-content: center;
}
.hs-rt-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: #bf5700;
    color: #fff !important;
    font-family: 'Oswald', 'Arial Narrow', sans-serif !important;
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none !important;
    padding: 0.6rem 1.5rem;
    border-radius: 0.375rem;
    transition: background 180ms ease, transform 180ms ease;
}
.hs-rt-btn:hover {
    background: #9e4700;
    transform: translateY(-1px);
}
.hs-rt-btn svg { flex-shrink: 0; }

/* ---- HOMETOWN HIDDEN VARIANT ---- */
.hs-rt-col-labels.hs-rt-no-hometown,
.hs-rt-entry.hs-rt-no-hometown {
    grid-template-columns: 2fr 0.6fr 1fr 1.1fr;
}

/* ---- RESPONSIVE ---- */
@media (max-width: 600px) {
    .hs-rt-col-labels { display: none; }

    /* Each entry: 2 rows
       Row 1: Name (spans all columns)
       Row 2: Position | [hometown if present] | Status
       The ranking star is hidden on mobile */
    .hs-rt-entry {
        display: grid !important;
        grid-template-columns: auto 1fr auto !important;
        grid-template-rows: auto auto !important;
        align-items: center;
        gap: 0.15rem 0.5rem;
        padding: 0.75rem 1rem;
    }

    /* Row 1: full-width name */
    .hs-rt-name {
        grid-column: 1 / -1 !important;
        grid-row: 1 !important;
        font-size: 0.95rem;
    }

    /* Row 2 col 1: position badge */
    .hs-rt-position {
        grid-column: 1 !important;
        grid-row: 2 !important;
        font-size: 0.8rem;
    }

    /* Row 2 col 2: hometown (if present) */
    .hs-rt-hometown {
        grid-column: 2 !important;
        grid-row: 2 !important;
        font-size: 0.75rem;
        color: #7a7570;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    /* Row 2 col 3: status badge — always far right */
    .hs-rt-status {
        grid-column: 3 !important;
        grid-row: 2 !important;
        justify-self: end;
    }

    /* Hide ranking stars on mobile */
    .hs-rt-ranking { display: none !important; }
}
