html {
  font-size: 14px;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

html {
  position: relative;
  min-height: 100%;
}

body {
  margin-bottom: 60px;
}

.matchup-line {
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Softer containers */
.card {
    border: 0;
    box-shadow: 0 0.25rem 0.75rem rgba(0,0,0,.05);
}

    .card .card-header {
        font-weight: 600;
    }

/* Dense, airy tables */
.table-sm td, .table-sm th {
    padding-top: .5rem;
    padding-bottom: .5rem;
}

.table thead th {
    font-weight: 600;
}

/* Odds buttons */
.btn-outline-primary, .btn-outline-secondary {
    border-width: 2px;
}

    .btn-outline-primary:hover, .btn-outline-secondary:hover {
        transform: translateY(-1px);
    }

.btn-outline-secondary {
    --bs-btn-color: var(--bs-gray-800);
}

/* Matchup truncation */
.matchup-line {
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Sticky right sidebar spacing */
.position-sticky {
    top: 1rem;
}

/* Floating bet slip button on mobile */
.betslip-fab {
    position: fixed;
    right: 1rem;
    bottom: 1rem;
    z-index: 1040;
}

/* Badge-like time slot pills (if you add them later) */
.slot-pill {
    font-size: .85rem;
    padding: .25rem .5rem;
    border-radius: 999px;
}

/* Cap slip height so it doesn't exceed viewport; body scrolls inside */
@media (min-width: 992px) {
    .position-sticky .card-body {
        max-height: calc(100vh - 6rem);
        overflow: auto;
    }
}

/* Slightly roomier slip rows */
.table .form-select.form-select-sm,
.table .form-control.form-control-sm {
    min-height: 2.1rem;
}
